- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
JPQL常用用法
2010-06-14
HYPERLINK http://blog/692018JPQL的一些用法
文章分类:HYPERLINK /blogs/category/javaJava编程
关联(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
您可能关注的文档
- 2013年江苏省公务员公共基础知识C类真题与答案.pdf
- 技术前沿--手机电视前途何在?.pdf
- 水工程施工第十一章给排水设备制作与安装.ppt
- 2013年驾考科目二倒车入库最详细实用图文详解.ppt
- 水污染控制原则与方法.ppt
- 橡胶沥青路面在江苏公路上应用研究.ppt
- 2013年职称计算机考试习题全集(Word版,包括WORD2003,EXCEL2003,POWERPOINT2003,WINDOWS_XP,INTERNET与试题.doc
- LPG用作城市燃气能源战略储备的研究.pdf
- 2013年职称计算机考试习题全集(Word版_包括WORD2003_EXCEL2003_POWERPOINT2003_WINDOWS_XP_INTERNET与试题.doc
- 2013正式第四课届高三政治(人教版)一轮精品:课时33_探究世界本质.ppt
文档评论(0)