Hibernate中的多表查询及抓取策略

作者:rodge 时间:2022-02-22 18:58:28 

1.Hibernate中的多表查询

 1.1SQL中的多表查询

【交叉连接】

select * from A,B;

【内连接】

显示内连接:inner join(inner 可以省略)

Select * from A inner join B on 条件;

隐式内连接:

Select * from A,B where 条件;

【外连接】

左外连接:left outer join

Select * from A left outer join B on 条件;

右外连接:right outer join

Select * from A right outer join B on 条件;

1.2Hibernate中的多表连接查询

【交叉连接】

交叉连接

【内连接】

显示内连接 from Customer c inner join c.linkmans

隐式内连接

迫切内连接from Customer c inner join fetch c.linkmans

【外连接】

左外连接

右外连接

迫切左外连接

2.Hibernate中的抓取策略

2.1 延迟加载lazy

lazy延迟加载: 查询的时候不发送sql语句,在使用对象的时候才发送sql语句查询

延迟加载氛围类级别的延迟加载和关联级别的延迟加载

2.1.1类级别的延迟加载

使用延迟加载的方法查询某个类的时候是否采用的延迟称为是类级别的延迟。默认值是true。

Customer customer = session.load(Customer.class,1l);// 默认就会采用延迟加载,这种称为是类级别的延迟。 

类级别延迟加载失效:

* final修饰这个类,不能产生代理类,延迟加载就会失效。

* 在<class>上配置lazy=”false”

2.1.2关联级别的延迟加载

查询到某个对象以后,获得其关联的对象。查询其关联对象的时候是否采用的延迟。称为是关联级别的延迟。


Customer c = session.get(Customer.class,1l);
c.getLinkMans(); // 查询关联对象的时候,是否采用延迟加载。

关联级别的延迟往往会与抓取策略一起使用,优化程序。(关联级别的延迟在<set>或者是<many-to-one>标签上的延迟加载)

2.2抓取策略

抓取策略指的是查找到某个对象后,抓取其关联的对象的时候采用的策略。抓取策略就是在关联对象的配置上(<set>和<many-to-one>)配置fetch属性。

2.2.1 在set上配置的lazy和fetch

fetch:抓取策略,控制SQL语句的发送的格式。

    * select    :默认值。发送一条select语句查询关联对象。

    * join  :发送一条迫切左外连接查询关联对象。

    * subselect :发送一条子查询查询关联对象。

lazy:延迟加载,控制SQL语句的发送的时候。

    * true  :默认值。采用延迟加载。

    * false :不采用延迟加载。

    * extra :及其懒惰。

2.2.2 在many-to-one上配置的lazy和fetch

fetch:抓取策略,控制SQL语句的发送的格式。

    * select    :默认值.发送一条select语句查询关联对象。

    * join  :发送一条迫切左外连接查询关联对象。

lazy:延迟加载,控制SQL的发送的时机。

    * proxy :默认值。是否采用延迟,需要由另一方类上的延迟加载来决定。

    * false :不采用延迟加载。

    * no-proxy:

2.2.3 批量抓取

批量抓取:查询了多个客户的时候,查询多个客户下的所有联系人。

在Customer.hbm.xml中<set>上配置batch-size=”n”

来源:http://www.cnblogs.com/rodge-run/p/6416032.html

标签:hibernate,查询,抓取策略
0
投稿

猜你喜欢

  • Jpa Specification如何实现and和or同时使用查询

    2023-10-17 20:49:38
  • Java静态代理和动态代理总结

    2022-01-02 18:49:21
  • MyBatis中XML 映射文件中常见的标签说明

    2023-01-07 08:02:59
  • 详谈C++引用&和指针在作为形参时的区别

    2023-12-13 16:50:49
  • 使用@PropertySource读取配置文件通过@Value进行参数注入

    2021-11-21 13:21:03
  • Java一个简单的红包生成算法

    2023-12-12 10:56:50
  • 教你创建一个带诊断工具的.NET镜像

    2021-09-28 03:11:11
  • jvm crash的崩溃日志详细分析及注意点

    2022-12-18 07:49:00
  • 详解Java中super的几种用法并与this的区别

    2023-07-12 01:21:23
  • Spring声明式事务和@Aspect的拦截顺序问题的解决

    2023-07-18 12:10:46
  • Java多线程程序中synchronized修饰方法的使用实例

    2022-05-08 16:38:56
  • SpringBoot中实现分布式的Session共享的详细教程

    2023-08-23 18:23:43
  • java获取文件的inode标识符的方法

    2021-06-19 15:10:49
  • 输出的文本实现对齐的方法(超简单)

    2023-06-19 03:57:09
  • idea 实现搜索jdk中的类和包操作

    2022-06-02 22:54:47
  • C#使用TextBox作数据输入方法

    2023-11-16 22:26:14
  • spring boot2结合mybatis增删改查的实现

    2023-07-07 01:17:31
  • JAVA版排序算法之快速排序示例

    2023-04-20 04:37:53
  • 浅谈SpringBoot资源初始化加载的几种方式

    2022-03-09 08:14:34
  • java 三种将list转换为map的方法详解

    2023-09-13 03:35:39
  • asp之家 软件编程 m.aspxhome.com