hibernate中,通过HQL进行多表连接查询返回结果集,例如同时返回了主表对象和从表对象,我的
hibernate中,通过HQL进行多表连接查询返回结果集,例如同时返回了主表对象和从表对象,我的问题是能否直接从主表对象引用从表对象的属性,如果不能那该怎么把匹配的主外...
hibernate中,通过HQL进行多表连接查询返回结果集,例如同时返回了主表对象和从表对象,我的问题是能否直接从主表对象引用从表对象的属性,如果不能那该怎么把匹配的主外键的对象的属性联系起来?谢谢。
展开
3个回答
展开全部
您好,如果你的主表javabean有子表的属性,然后在XML映射了该属性,
那么可以直接从主表对象引用从表对象的属性,
Hibernate对这种映射默认都是懒加载的,你开始查询主表对象的时候,从sql上就可以看出来不会去查询子表,
当你使用主表对象上面的从表对象的时候,Hibernate才用left out join的方式查询子表。
希望对你有帮助。
那么可以直接从主表对象引用从表对象的属性,
Hibernate对这种映射默认都是懒加载的,你开始查询主表对象的时候,从sql上就可以看出来不会去查询子表,
当你使用主表对象上面的从表对象的时候,Hibernate才用left out join的方式查询子表。
希望对你有帮助。
更多追问追答
追问
a是主表对象,包含了一个set 类型的从表对象,怎么用a去引用每一个从表对象的属性,怎么个写法?
追答
这个没办法的,你获取a对象的那个set集合,然后可以迭代获取到每个从对象。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
现在假设A是主表B是从表,写HQL的时候可以这样写select A.A表生成的类中的外键名.B表的字段名 from A
A表生成的类中的外键名一般是B表的名称,这样的话就可以把B表你要的任何字段都搜出来了。
594266756那位的方法也可以,我这个方法不用改配置文件,他的方法如果你要取的是ID的话也不用改lazy="false"
A表生成的类中的外键名一般是B表的名称,这样的话就可以把B表你要的任何字段都搜出来了。
594266756那位的方法也可以,我这个方法不用改配置文件,他的方法如果你要取的是ID的话也不用改lazy="false"
更多追问追答
追问
.主表会配置它的外键吗? 那岂不成了从表。
追答
sorry,失误
A是从表B是主表
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询