JPQL:无法将字段路径解析为集合类型

时间:2014-01-20 11:27:24

标签: jpa jpql

我正在尝试根据用户可以选择的可能日期列表对日期进行搜索。使用日历,我要求用户输入日期,然后我想在“data_possibile”列表中获取所有可能包含该日期的数据包。

这是我正在使用的查询:

@NamedQuery(name="pacchettoPreconfigurato.findVendibileByData", query="SELECT p FROM PacchettoPreconfigurato p WHERE p.in_vendita=TRUE AND (:data) IN (p.date_possibili)")

现在,当我尝试在服务器的日志中部署应用程序时,我得到了:

Exception Description: Problem compiling [SELECT p FROM PacchettoPreconfigurato p WHERE p.in_vendita=TRUE AND (:data) IN (p.date_possibili)]. [81, 97] The state field path 'p.date_possibili' cannot be resolved to a collection type.

这就是p.date_possibili的定义方式:

@OneToMany(orphanRemoval=true)
@JoinColumn(name="id_pp")
private List<DataPossibilePP> date_possibili;

DataPossibilePP是:

@Entity
@IdClass(DataPossibilePPPK.class)
public class DataPossibilePP implements Serializable {     
    @Id
    private Integer id_pp;   
    @Id
    private Date data;
    private static final long serialVersionUID = 1L;
    /*standard getters and setters*/
}

我不明白为什么我被告知该字段不是一个集合,即使它被定义为一个列表而Eclipse本身也在其自动完成中暗示它。

如何编写查询以便编译?

1 个答案:

答案 0 :(得分:5)

in运算符不能用于集合。它应该用在作为参数传递给查询的值列表中,或者用在子选择上。

您可能正在寻找member of运算符,它会测试某个参数是否属于集合的一部分:

select student from Student student where :course member of student.courses