zoukankan      html  css  js  c++  java
  • Hibernate的检索方式(三)【转】

    版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
    http://aumy2008.blogbus.com/logs/13941318.html

    三、连接查询

    HQLQBC支持的各种连接类型

    在程序中指定的链接查询类型

    HQL语法

    QBC语法

    使用范围

    内连接

    inner join 或者 join

    Criteria.createAlias()

    适用于有关联的持久化类,并且在映射文件中对这种关联关系作了映射。

    迫切内连接

    inner join fetch 或者 join fetch

    不支持

    隐式内连接

     

    不支持

    左外连接

    left outer join 或者 left join

    不支持

    迫切左外连接

    left outer join fetch 或者 left join fetch

    FetchMode.EAGER

    右外连接

    right outer join 或者 right join

    不支持

    交叉连接

    ClassA,ClassB

    不支持

    适用于不存在关联关系的持久化类

     

    1、默认情况下关联级别的运行时检索策略

           采用配置文件中设置的检索策略,但有一个例外,那就是HQL会忽略映射文件设置的迫切左外连接策略,改用立即检索。

     

    2、迫切左外连接

           显式指定对象的关联关系为迫切左外连接检索策略,可以覆盖映射文件中指定的检索策略。

    HQL

    "from Customer c left join fetch c.orders o where c.name like 't%'"

    +" o.name like 't%'"

    QBC

        List reslut=session.createCriteria(Customer.class)    .setFetchMode("orders",FetchMode.EAGER)    .add(Expression.like("name","t",MatchMode.START))

        .list();

     

           当使用迫切左外连接检索策略时,查询结果中可能会包含重复元素,可以通过一个HashSet来过滤重复元素:List result=….list(); HashSet set=new HashSet(result);

           Hibernate允许在一条查询语句中迫切左外连接多个多对一或一对一关联的类。

         List reslut=session.createCriteria(A.class)     .setFetchMode("this.b",FetchMode.EAGER)     .setFetchMode("this.c",FetchMode.EAGER)     .add(Expression.isNotNull("this.b"))     .add(Expression.isNotNull("this.c"))

         .list();

     

           当存在传递关联时,可以通过HQL来同时迫切左外连接关联类和依赖关联类,但QBC无法表达这种形式的迫切左外连接。

     

    3、左外连接

           使用左外连接查询时,将根据映射文件的配置来决定关联的检索策略。

     

    4、内连接

           QBC也支持内连接查询

         List reslut=session.createCriteria(Customer.class)     .add(Expression.like("name","t",MatchMode.SRART))     .createCriteria("orders")     .add(Expression.like("orderNumber","t",MatchMode.SRART))

         .list();

           默认情况下,QBC只检索出Customer对象,以上代码等同于以下HQL查询语句:

    "select c from Customer c join c.orders o where c.name like 't%'"

                  + " and o.orderNumber like 't%'";

     

           createAlias()方法为关联属性(集合)赋予别名。如果希望QBC返回的集合也包含成对的CustomerOrder对象,可以调用returnMaps()方法:

         List reslut=session.createCriteria(Customer.class)     .createAlias("orders","o")     .add(Expression.like("this.name","t",MatchMode.SRART))     .add(Expression.like("o.orderNumber","t",MatchMode.SRART))     .returnMaps()

         .list();

     

           采用内连接查询时,HQLQBC有不同的默认行为,前者检索成对的对象,后者仅检索出要检索的单个对象(不包含关联的对象)。

     

    5、迫切内连接

           显式指定对象的关联关系为迫切内连接检索策略,可以覆盖映射文件中指定的检索策略。

     

    6、隐式内连接

    一对一

    "from Cunstomer c where c.homeAddress.provice like '%hai%'"

          List reslut=session.createCriteria(Customer.class)     .add(Expression.like("homeAddress.provice","t",MatchMode.SRART))

         .list();

     

    多对一

    "from Order o where o.customer.name like '%hai%'"

    QBC 不支持隐式内连接,下边是不正确的,:

         List reslut=session.createCriteria(Order.class)     .add(Expression.like("customer.name","t",MatchMode.SRART))

         .list();

    对于QBC,必须显式指定内连接查询:

         List reslut=session.createCriteria(Order.class)     .createAlias("customer","c")     .add(Expression.like("c.name","t",MatchMode.SRART))

         .list();

     

    一对多或多对多

           隐式内连接不适用。

     

    7、右外连接

     

    8、使用SQL风格的交叉连接和隐式内连接

           HQL支持SQL风格的交叉连接查询。如: from Customer c, Order o

     

           SQL语言中,显式内连接查询的语句使用inner join关键字,并且用on字句设定连接条件,形式为:

    "select * from CUSTOMER c inner join ORDER o on c.ID=o.CUSTOMER_ID"

           隐式内连接查询语句不包含关键字阿,并且用where字句设定连接条件:

    "select * from CUSTOMER c ,ORDER o where c.ID=o.CUSTOMER_ID"

     

    9、关联级别运行是的检索策略

    1)没有显式指定,使用配置文件的,但有一个例外,那就是HQL会忽略映射文件设置的迫切左外连接策略,改用立即检索。

    2)如果显式指定,就会覆盖映射文件配置的检索策略。在HQL查询语句中显式指定检索策略包括以下内容。

    l         left join fetch

    l         inner join fetch

    QBC通过FetchMode类来显式指定检索策略,有以下3个静态实例。

    l         FetchMode.DEFAULT:默认,采用配置;

    l         FetchMode.EAGER:覆盖,指定迫切左外连接检索策略;

    l         FetchMode.LAZY:覆盖映射配置文件的检索策略,在程序中指定延迟检索策略。

     待续!
  • 相关阅读:
    java作业5
    《大道至简》第五章读后感
    java作业4
    《大道至简》第四章读后感
    java作业3
    《大道至简》第三章读后感
    java作业2
    Java课程作业1
    《大道至简》第二章读后感
    《大道至简》第一章读后感
  • 原文地址:https://www.cnblogs.com/myssh/p/1438801.html
Copyright © 2011-2022 走看看