异常org.hibernate.QueryException: could not resol...

徘徊边缘 提交于 2019-12-04 06:59:21

异常消息如下所示:
严重: Servlet.service() for servlet action threw exception
org.hibernate.QueryException: could not resolve property: roleId of: com.sidi.vo.Roleitem [update com.sidi.vo.Roleitem ri set ri.isShow = '0' where ri.roleId=?]

org.hibernate.QueryException: could not resolve property: task_no of: edu.cust.entity.Task
对应的语句是dao中的更新方法
String queryString = "update Roleitem ri set ri.isShow = '0' where ri.roleId=?";

这个地方的roleId是在roleitem表中的,但只是此表的一个外键,所以应该写成
String queryString = "update Roleitem ri set ri.isShow = '0' where ri.role.roleId=?";
问题解决!!
===================================这是别人的一个例子===============

at org.hibernate.persister.entity.AbstractPropertyMapping.throwPropertyException(AbstractPropertyMapping.java:43)
这里,关键是“task_no of: edu.cust.entity.Task”,task_no为数据库中表的字段,异常时说在查询的时候无法解析这个字段,也就是说这个字段是错误的。

由于Eclipse能够进行Hibernate映射,并自动生成持久化类和对应的配置文件,对于类似于task_no中带有下划线的字段,则自动将下划线去掉,task_no在持久化类中对应属性为taskNo,所以,在Dao中编写查询的方法中,必须写成

criteria.add(Restrictions.eq("taskNo",task.getTaskNo()));

这里eq()方法的第一个参数对应于持久化类中的属性名称,如果使用下面:

criteria.add(Restrictions.eq("task_no",task.getTaskNo()));

就可能发生上面的异常,千万要小心。

一般地,如果涉及到属性类型无法解析的异常,可能出现问题的地方有:

数据库字段与持久化类映射文件,以及持久化类文件中属性名称或者类型可能不相匹配;

持久化类映射文件中属性类型可能有问题,比如,如果使用Java类型,注意大写(如type="java.lang.String"),如果使用Hibernate类型,使用小写(如type="string")。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!