HQL:在命名查询中使用布尔值

时间:2012-01-05 07:54:29

标签: hibernate hql boolean named

你能帮帮我吗?我在查询布尔值“r.isDefault = true”时遇到错误。

在我的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

感谢。

1 个答案:

答案 0 :(得分:41)

试试这个:where r.isDefault is true