异常消息如下所示:
严重: 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")。
来源:oschina
链接:https://my.oschina.net/u/856612/blog/95935