many to one could not resolve property

本文解决了Hibernate查询中出现的Couldnotresolveproperty错误。通过调整Criteria API的使用方式,即在查询StudentExam实体时,先指定外部实体再精确到内部实体属性的方法,成功解决了这一难题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在做一个功能的时候
遇到了。一个Could not resolve property 的问题。

配置文件如下:
<many-to-one name="user"  class="Users" column="StudentExam_user_fid" cascade="all" ></many-to-one>


查询代码:
    Criteria crt = session.createCriteria(StudentExam.class).add(Restrictions.eq("exam.id", ExamId)).add(
Restrictions.eq("reading", reading)).add(Restrictions.like("user.truename", name));

return crt.setFirstResult(start).setMaxResults(max).list();


在网上找了好久。所有人给的理由都是“对照配置文件以及实体类,是否写错了字段名称”
在我一再的确认下,字段名称没有任何错误……
而且使用user.id是可以进行查询的。除了这个以外。别的都不可以用!
于是开始对配置文件进行修改。尝试了 lazy设置为false 等等。。想对应的修改
Users配置文件的修改。未果

最后,经过各种挣扎。以及Hibernate相关API的查找。最终终于找出解决办法
    Criteria crt = session.createCriteria(StudentExam.class).add(Restrictions.eq("exam.id", ExamId)).add(
Restrictions.eq("reading", reading)).createCriteria("user").add(Restrictions.like("truename", name));


对。就是这样写。在使用完StudentExam里的属性后。
.createCriteria("user")
设置到user实体里。然后再选择属性
注:这里的user是StudentExam类中的名称
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值