2012-01-05 80 views
13

你能帮我吗?我在查询布尔值“r.isDefault = true”时出错。HQL:在命名查询中使用布尔值

在我的HQL命名查询:

<named-query name="RptQuery.queryDefaultByCode"> 
    <query> 
     SELECT r FROM RptQuery r WHERE r.code = ?1 AND r.isDefault = true 
    </query> 
</named-query> 

我得到错误: 引起:org.hibernate.HibernateException:错误的命名查询:RptQuery.queryDefaultByCode

在我的persistence.xml:

<property name="hibernate.query.substitutions" value="true='Y', false='N', yes='Y', no='N'"/> 

在我的POJO:

private boolean isDefault; 

@Column(name = "CPMN_IS_DEFLT", length = 1) 
@Type(type = "yes_no") 
public boolean isDefault() { 
    return this.isDefault; 
} 

public void setDefault(boolean isDefault) { 
    this.isDefault = isDefault; 
} 

预先感谢您!

答: 刚刚发现一个小错误:

r.isDefault = true 

应该

r.default = true 

感谢。

回答

36

试试这个:where r.isDefault is true