我正在尝试根据用户可以选择的可能日期列表对日期进行搜索。使用日历,我要求用户输入日期,然后我想在“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本身也在其自动完成中暗示它。
如何编写查询以便编译?
答案 0 :(得分:5)
in
运算符不能用于集合。它应该用在作为参数传递给查询的值列表中,或者用在子选择上。
您可能正在寻找member of
运算符,它会测试某个参数是否属于集合的一部分:
select student from Student student where :course member of student.courses