最近在工作中尝试使用Criteria来代替hql的功能,为什么呢?因为觉得到处使用hql,尤其是比较复杂的查询,就有种使用jdbc的感觉.
在使用Expression.eq(String propertyName, Object value)方法的时候,出现了一个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类型
在使用Expression.eq(String propertyName, Object value)方法的时候,出现了一个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类型