- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JPQL的常用用法
2010-06-14
JPQL的一些用法
文章分类:Java编程
关联(join) JPQL仍然支持和SQL中类似的关联语法: left out join/left join inner join left join fetch/inner join fetch left out join/left join等,都是允许符合条件的右边表达式中的Entiies 为空(需要显式使用left join/left outer join 的情况会比较少。) 例: //获取26岁人的订单,不管Order中是否有OrderItem select o from Order o left join o.orderItems where o.ower.age=26 order by o.orderid inner join 要求右边的表达式必须返回Entities。 例: //获取26 岁人的订单,Order 中必须要有OrderItem select o from Order o inner join o.orderItems where o.ower.age=26 order by o.orderid !!重要知识点:在默认的查询中,Entity中的集合属性默认不会被关联,集合属性默认是延迟加载( lazy-load )。那么,left fetch/left out fetch/inner join fetch提供了一种灵活的查询加载方式来提高查询的性能。 例: private String QueryInnerJoinLazyLoad(){ // 默认不关联集合属性变量(orderItems)对应的表 Query query = em.createQuery(select o from Order o inner join o.orderItems where o.ower.age=26 order by o.orderid); List result = query.getResultList(); if (result!=null result.size()0){ //这时获得Order 实体中orderItems( 集合属性变量)为空 Order order = (Order) result.get(0); //当需要时,EJB3 Runtime才会执行一条SQL语句来加载属于当前Order的 //OrderItems SetOrderItem list = order.getOrderItems(); IteratorOrderItem iterator = list.iterator(); if (iterator.hasNext()){ OrderItem orderItem =iterator.next(); System.out.println (订购产品名:+ orderItem.getProductname()); } } 上面代码在执行select o from Order o inner join o.orderItems where o.ower.age=26 order by o.orderid时编译成的SQL如下(他不包含集合属性变量(orderItems)对应表的字段): select order0_.orderid as orderid6_, order0_.amount as amount6_, order0_.person_id as person4_6_, order0_.createdate as createdate6_ from Orders order0_ inner join OrderItems orderitems1_ on order0_.orderid=orderitems1_.order_id, Person person2_ where order0_.person_id=person2_.personid and person2_.age=26 order by order0_.orderid 上面代码当执行到SetOrderItem list = order.getOrderItems();时才会执行一条SQL语句来加载属于当前Order的OrderItems,编译成的SQL 如下: select orderitems0_.order_id as order4_1_, orderitems0_.id as id1_, orderitems0_.id as id7_0_, orderitems0_.order_id as order4_7_0_, orderitems0_.prod
您可能关注的文档
- 591UP历史资源-名师原创精题+选修一+专题三-王老师名师原创精题+选修一+专题三(教师版).doc
- 2016年下半年网络规划设计师官方指定教程.docx
- 5、竞赛作品申报书样本.doc
- 2016年春季大学英语高起专网上作业及答案(一).doc
- 6 2009年全国中考英语试题完形填空汇编及答案.doc
- 25个必须记住的SSH命令.docx
- 2、单调性与最大(小)值-说课稿.docx
- 65岁以上老人免费体检培训材料.doc
- 30秒自制简单程序.doc
- 3.4 网络信息交流.doc
- 《GB/T 32879-2025电动汽车更换用电池箱连接器》.pdf
- 中国国家标准 GB/T 21649.2-2025粒度分析 图像分析法 第2部分: 动态图像分析法.pdf
- 中国国家标准 GB/T 20899.9-2025金矿石化学分析方法 第9部分:碳量的测定.pdf
- 《GB/T 20899.9-2025金矿石化学分析方法 第9部分:碳量的测定》.pdf
- GB/T 20899.9-2025金矿石化学分析方法 第9部分:碳量的测定.pdf
- 《GB/T 33820-2025金属材料 延性试验 多孔状和蜂窝状金属高速压缩试验方法》.pdf
- GB/T 33820-2025金属材料 延性试验 多孔状和蜂窝状金属高速压缩试验方法.pdf
- 中国国家标准 GB/T 33820-2025金属材料 延性试验 多孔状和蜂窝状金属高速压缩试验方法.pdf
- GB/T 45910-2025信息技术 生物特征识别模板保护方案的性能测试.pdf
- 《GB/T 45910-2025信息技术 生物特征识别模板保护方案的性能测试》.pdf
最近下载
- 动量定理精选习题+答案.pdf VIP
- 2025江苏盐城市黄海金融控股集团有限公司博士后创新实践基地研究人员招聘2人笔试备考题库及答案解析.docx VIP
- 2025江苏盐城市黄海金融控股集团有限公司博士后创新实践基地研究人员招聘2人笔试参考题库附答案解析.docx VIP
- 2025江苏盐城市黄海金融控股集团有限公司博士后创新实践基地研究人员招聘2人笔试模拟试题及答案解析.docx VIP
- 2025江苏盐城市黄海金融控股集团有限公司博士后创新实践基地研究人员招聘2人考试备考试题及答案解析.docx VIP
- 教师资格证面试结构化面试真题及解析(幼儿园).pdf VIP
- KYN61-40.5型开关柜技术规范书.docx VIP
- 夜市承包经营协议书.docx VIP
- 2025江苏盐城市黄海金融控股集团有限公司博士后创新实践基地研究人员招聘2人考试备考题库及答案解析.docx VIP
- 2025届广东省深圳实验学校高中部高三第二次联考化学试卷含解析.doc VIP
文档评论(0)