浅谈hibernate急迫加载问题(多重外键关联)-创新互联

数据库结构如下

我们拥有10多年网页设计和网站建设经验,从网站策划到网站制作,我们的网页设计师为您提供的解决方案。为企业提供网站设计、成都做网站、微信开发、微信小程序定制开发手机网站制作设计H5建站、等业务。无论您有什么样的网站设计或者设计方案要求,我们都将富于创造性的提供专业设计服务并满足您的需求。

strategy中有外键member_id(关联member表)外键strategy_category(关联category表)而member表中有外键position_id(关联positons表)

如果前台页面直接查询stategy表中内容我们hql语句如果这么写

Stringhql="FromStrategywhereid=:id";

控制台会报nosession错误这是因为hibernate默认懒加载只有我们需要的时候才会将关联的对象加载出来这里在我们前台需要取关联对象中的属性的时候session已经关闭了额才会报这样的错误

那么如何解决呢

这里建议使用leftjoinfetch的方式来加载对象而不是将注解中默认的懒加载改为急迫加载效率会很低

语句如下

Strategystrategy=(Strategy)sessionFactoryUtil.getSession()

.createQuery("FromStrategysleftjoinfetchs.strategyCategoryleftjoinfetchs.memberleftjoinfetchs.member.positionswheres.id=:id")

.setInteger("id",id).uniqueResult();

网站栏目:浅谈hibernate急迫加载问题(多重外键关联)-创新互联
链接分享:http://bzwzjz.com/article/gdedc.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 盐亭网站设计 手机网站制作 高端品牌网站建设 品牌网站建设 成都网站设计 网站设计制作报价 定制级高端网站建设 成都网站设计 品牌网站建设 手机网站建设 专业网站建设 营销型网站建设 H5网站制作 手机网站制作 重庆网站设计 成都网站制作 重庆网站建设 网站建设公司 网站制作 达州网站设计 温江网站设计 成都网站设计