java - 为什么我的 JPQL 不工作?

标签 java jakarta-ee websphere jpql rad

这个 JPQL 曾经可以工作,但后来无缘无故地崩溃了。我现在得到这个奇怪的异常:

java.lang.IllegalArgumentException: Parameter "Parameter<LandKod>('landKod')" declared in "SELECT r FROM Region r WHERE r.landKod = :landKod" is set to value of "US" of type "java.lang.String", but this parameter is bound to a field of type "se.prv.pandora.arendeprocess.entity.LandKod".

这似乎表明我的代码中名为 landKod 的内容存在某种名称冲突。来源如下:

import java.io.Serializable;

import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.Table;

@Entity(name = "Region")
@Table(name="TP197_REGION")

@NamedQueries({
    @NamedQuery(name = "getAllValidRegions", query = "SELECT r FROM Region r WHERE r.histKod = 'A'"), 
    @NamedQuery(name = "getRegionsByLandkod", query = "SELECT r FROM Region r WHERE r.landKod = :landKod")
})

public class Region implements Serializable {

    @Id
    private int regionId;

    @ManyToOne
    @JoinColumn(name="landKod", referencedColumnName="landKod")
    private LandKod landKod ;

    private String histKod ;
    private String regionForkort;
    private String regionRubrik;
    private String regionBeskr;

    public Region() {
        super();
    }


    public int getRegionId() {
        return regionId;
    }


    public void setRegionId(int regionId) {
        this.regionId = regionId;
    }


    public String getRegionForkort() {
        return regionForkort;
    }

    public void setRegionForkort(String regionForkort) {
        this.regionForkort = regionForkort;
    }

    public String getRegionRubrik() {
        return regionRubrik;
    }

    public void setRegionRubrik(String regionRubrik) {
        this.regionRubrik = regionRubrik;
    }

    public String getRegionBeskr() {
        return regionBeskr;
    }

    public void setRegionBeskr(String regionBeskr) {
        this.regionBeskr = regionBeskr;
    }


    public String getHistKod() {
        return histKod;
    }


    public void setHistKod(String histKod) {
        this.histKod = histKod;
    }


    public String getRegionFormatted() {
        if(regionForkort!=null && regionForkort.length()>0) {
            return regionForkort + " " + regionRubrik;
        } else {
            return regionRubrik;

        }
    }


    public LandKod getLandKod() {
        return landKod;
    }


    public void setLandKod(LandKod landKod) {
        this.landKod = landKod;
    }


}

这是允许字符串作为参数的方法实现:

@Override
public List<Region> getRegionsByLandkod(String landKod) {

    List<Region> regionsList = null;


try {

    Query query = em.createNamedQuery("getRegionsByLandkod");
    query.setParameter("landKod", landKod);
    regionsList =  (List<Region>) query.getResultList();

} catch(Exception e){ 
    logger.info("Kunde inte hitta någon region med landkod: "+landKod, e);
}

return regionsList;
}

你能帮我解决这个错误吗?

最佳答案

问题出在这一行:

   public List<Region> getRegionsByLandkod(String landKod) {

应该是这样的:

   public List<Region> getRegionsByLandkod(LandKod landKod) {

或者您应该将字符串转换为 LandKod 并使用 that 作为查询参数。

(或者您可以更改 Region 类以使 landKod 属性的类型为 String。)

关于java - 为什么我的 JPQL 不工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10598378/

相关文章:

java - 在 Spring MVC 3.0 中允许音频文件?

MicroProfile 的 WebSphere Application Server 支持

java - 如果在一个事务中我们只在一个数据源上写入,是否可以避免 2PC 或手动处理提交? (J2CA0030E)

java - 双重检查锁定,NetBeans 让我感到困惑?

Java:包含 "this"参数或让它隐含

multithreading - JSF 中的线程?

jsp - Java 前端 Controller

java - 打开dolphin保持3000个对象同步到客户端

java - 直接来自 Clojure Repl 的 Browning javadoc

jakarta-ee - 针对特定客户端-服务器系统的建议