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

异常消息如下所示:
严重: 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")。

转载于:https://my.oschina.net/u/856612/blog/95935

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值