JPQL的常用用法.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档