异常消息以下所示:
严重: 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=?] java
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为数据库中表的字段,异常时说在查询的时候没法解析这个字段,也就是说这个字段是错误的。 app
因为Eclipse可以进行Hibernate映射,并自动生成持久化类和对应的配置文件,对于相似于task_no中带有下划线的字段,则自动将下划线去掉,task_no在持久化类中对应属性为taskNo,因此,在Dao中编写查询的方法中,必须写成 spa
criteria.add(Restrictions.eq("taskNo",task.getTaskNo())); hibernate
这里eq()方法的第一个参数对应于持久化类中的属性名称,若是使用下面: ip
criteria.add(Restrictions.eq("task_no",task.getTaskNo())); get
就可能发生上面的异常,千万要当心。 servlet
通常地,若是涉及到属性类型没法解析的异常,可能出现问题的地方有: string
数据库字段与持久化类映射文件,以及持久化类文件中属性名称或者类型可能不相匹配; it
持久化类映射文件中属性类型可能有问题,好比,若是使用Java类型,注意大写(如type="java.lang.String"),若是使用Hibernate类型,使用小写(如type="string")。