`
Michael.solofly
  • 浏览: 59042 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

many to one could not resolve property

阅读更多
今天在做一个功能的时候
遇到了。一个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类中的名称



0
1
分享到:
评论
5 楼 fyso1983 2013-08-07  
很赞,有用。终于解决了,感谢啊!
4 楼 liubiaocai 2013-02-19  
受教了,终于搞定了
3 楼 aaa5131421 2010-11-26  
的。除了这个以外。别的都
Michael.solofly 写道
你能说全你的问题么。

和你的问题一模一样,我仔细看了一下,当不能用.导航到关联表的时候 此时 hibernate生成的sql是 两表并列:from table1, table2
而我记得好像以前可以用。导航的时候生成的sql是这样的:from table1 join table2 on...
而在cretera中又调用 createCretiera 或者 createAlise方法 生成的sql 又变成 join的方式了
估计问题症结就是出现在用。导航为什么生成的sql不是 join方式 这个问题上!
2 楼 Michael.solofly 2010-11-25  
你能说全你的问题么。
1 楼 aaa5131421 2010-11-15  
晕了 我记得用。导航的方式一直是好使的呀~~ 谁能告诉我为什么突然就不好使了呢

相关推荐

Global site tag (gtag.js) - Google Analytics