hibernate中Expression.eq(String propertyName, Object value)的使用注意点

最近在工作中尝试使用Criteria来代替hql的功能,为什么呢?因为觉得到处使用hql,尤其是比较复杂的查询,就有种使用jdbc的感觉.

在使用Expression.eq(StringpropertyName,Objectvalue)方法的时候,出现了一个java.lang.ClassCastException:java.lang.String异常,很郁闷,看不出来是什么地方出了问题?后来,不知怎么就找到了这个错误原因

原来是eq方法的第二个参数类型应该使用与PO对象中此字段相同的类型,虽然在这里这个方法是Object类型.

示例代码(错误使用方式):

crit.add(Expression.eq("listId",String.valueOf(listId)));

代码代码(正确使用方式):

crit.add(Expression.eq("listId",listId));

主键值listId是Long类型,参数value的类型只能是Long,不可以是String类型

相关推荐