`
为了明天
  • 浏览: 114592 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

关于hiberante FetchMode

阅读更多
以Person, Address 为例, 其关系为一对多,数据库中有3条person, 每个分别对应2条address。查询语句如下:




Java代码 
1.Criteria c = session.createCriteria(Person.class);  
2.c.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);  
3.List<Person> list = (List<Person>)c.list();  
4.for (Person p : list) {  
5.        System.out.println(p.getName());  
6.              
7.    Set<Address> addressSet = p.getAddressSet();  
8.    for (Address a : addressSet) {  
9.        System.out.println(a);  
10.    }             
11.}  



1 默认不设置FetchMode



Java代码 
1.@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)  
2.@JoinColumn(name = "P_ID")  
3.public Set<Address> getAddressSet() {  
4.    return addressSet;  
5.}  



结果生成如下



Java代码 
1.Hibernate: select this_.PERSON_ID as PERSON1_0_0_, this_.PERSON_NAME as PERSON2_0_0_   
2.from PERSON this_  
3.P1  
4.Hibernate: select addressset0_.P_ID as P3_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_0_, addressset0_.ADDRESS_NAME as ADDRESS2_1_0_   
5.from ADDRESS addressset0_   
6.where addressset0_.P_ID=?  
7.2   P1 A2  
8.1   P1 A1  
9.P2  
10.Hibernate: select addressset0_.P_ID as P3_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_0_, addressset0_.ADDRESS_NAME as ADDRESS2_1_0_   
11.from ADDRESS addressset0_   
12.where addressset0_.P_ID=?  
13.4   P2 A2  
14.3   P2 A1  
15.P3  
16.Hibernate: select addressset0_.P_ID as P3_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_0_, addressset0_.ADDRESS_NAME as ADDRESS2_1_0_   
17.from ADDRESS addressset0_   
18.where addressset0_.P_ID=?  
19.5   P3 A1  
20.6   P3 A2  


即:先查所有Person的id, 然后根据id查对应的Address。产生N+1问题

2. FetchMode.SELECT




Java代码 
1.@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)  
2.@Fetch(FetchMode.SELECT)  
3.@JoinColumn(name = "P_ID")  
4.public Set<Address> getAddressSet() {  
5.    return addressSet;  
6.}  


效果同默认,即hibernate默认的FetchMode是SELECT

3. FetchMode.JOIN



Java代码 
1.@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)  
2.@Fetch(FetchMode.JOIN)  
3.@JoinColumn(name = "P_ID")  
4.public Set<Address> getAddressSet() {  
5.    return addressSet;  
6.}  


效果如下



Java代码 
1.Hibernate: select this_.PERSON_ID as PERSON1_0_1_, this_.PERSON_NAME as PERSON2_0_1_, addressset2_.P_ID as P3_3_, addressset2_.ADDRESS_ID as ADDRESS1_3_, addressset2_.ADDRESS_ID as ADDRESS1_1_0_, addressset2_.ADDRESS_NAME as ADDRESS2_1_0_   
2.from PERSON this_   
3.   left outer join ADDRESS addressset2_   
4.        on this_.PERSON_ID=addressset2_.P_ID  
5.  
6.P1  
7.2   P1 A2  
8.1   P1 A1  
9.P2  
10.4   P2 A2  
11.3   P2 A1  
12.P3  
13.5   P3 A1  
14.6   P3 A2  



采用外联,用一条sql取出person及其address

4. FetchMode.SUBSELECT



Java代码 
1.@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)  
2.@Fetch(FetchMode.SUBSELECT)  
3.@JoinColumn(name = "P_ID")  
4.public Set<Address> getAddressSet() {  
5.    return addressSet;  
6.}  



效果



Java代码 
1.Hibernate: select this_.PERSON_ID as PERSON1_0_0_, this_.PERSON_NAME as PERSON2_0_0_   
2.from PERSON this_  
3.P1  
4.Hibernate: select addressset0_.P_ID as P3_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_0_, addressset0_.ADDRESS_NAME as ADDRESS2_1_0_   
5.from ADDRESS addressset0_   
6.where addressset0_.P_ID in (select this_.PERSON_ID from PERSON this_)  
7.2   P1 A2  
8.1   P1 A1  
9.P2  
10.4   P2 A2  
11.3   P2 A1  
12.P3  
13.6   P3 A2  
14.5   P3 A1 


生成2条sql, 第二句用in 查关联Address数据


5. batchSize



Java代码 
1.@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)  
2.@BatchSize(size=4)  
3.@JoinColumn(name = "P_ID")  
4.public Set<Address> getAddressSet() {  
5.    return addressSet;  
6.}  


效果



Java代码 
1.Hibernate: select this_.PERSON_ID as PERSON1_0_0_, this_.PERSON_NAME as PERSON2_0_0_   
2.from PERSON this_  
3.P1  
4.Hibernate: select addressset0_.P_ID as P3_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_, addressset0_.ADDRESS_ID as ADDRESS1_1_0_, addressset0_.ADDRESS_NAME as ADDRESS2_1_0_   
5.from ADDRESS addressset0_   
6.where addressset0_.P_ID in (?, ?, ?)  
7.1   P1 A1  
8.2   P1 A2  
9.P2  
10.4   P2 A2  
11.3   P2 A1  
12.P3  
13.5   P3 A1  
14.6   P3 A2  


生成2条sql,第二条用in。 这里数据库中共有3条person。
如果设size=0或1, 则效果同select一样,产生N+1问题。
如size=2, 生成3条sql,第一条相同,第二条为



Java代码 
1.select 。。。。  
2.from ADDRESS addressset0_   
3.where addressset0_.P_ID in (?, ?)  


第三条为



Java代码 
1.select。。  
2.from ADDRESS addressset0_   
3.where addressset0_.P_ID=?  



如果设size=3则生成2条sql,第一条相同,第一条为



Java代码 
1.select 。。。。  
2.from ADDRESS addressset0_   
3.where addressset0_.P_ID in (?, ?, ?)  


由上,size即为in中数据个数。
分享到:
评论

相关推荐

    hiberante3 注解帮助文档

    hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档

    最新springboot2hiberante5项目

    最新springboot2基础hiberante5完整项目,打包jar,运行jsp,包括后台与前台,拦截器,登录,后台下载就可以使用,注意不是jpa,里面有完整Dao,千万级数据项目分离的代码,为了适合老项目开发特意集成hiberante5....

    DAO层中对Hiberante

    在Java的持久化框架中,Hibernate是一个非常流行的ORM(对象关系映射)工具,它允许开发者将数据库操作转化为对Java对象的操作。DAO(Data Access Object)层是软件设计模式中的一个重要概念,主要用于处理数据访问...

    hiberante 源码 配置资料

    源码中的`org.hibernate.mapping`包下包含了许多关于对象持久化的类和接口。 3. 数据库交互:Hibernate通过JDBC进行数据库操作,`org.hibernate.engine.jdbc`包下包含了对JDBC的封装。例如,ConnectionProvider负责...

    Hiberante 有关jar包

    Hibernate Tools是一套全新而且完整的面向Hibernate3的工具集合,它包含了Eclipse插件和Ant编译流程。Hibernate Tools是JBoss Tools的核心组件,所以他也是JBoss Developer Studio的一部分

    spring+mvc+hiberante

    Spring 框架是 Java 企业级应用开发中的核心组件,它提供了全面的软件基础设施,包括依赖注入(DI)、面向切面编程(AOP)以及众多的模块如数据访问、Web 应用、任务调度等。Spring MVC 是 Spring 框架的一部分,...

    Hiberante3.jar + API

    《Hibernate3.jar与API详解》 Hibernate,作为一个强大的对象关系映射(ORM)框架,是Java开发者在处理数据库操作时的得力助手。本篇将深入探讨Hibernate3.jar及其API,帮助开发者更好地理解和运用这个库。...

    Struts+Hiberante+Sprint 框架整合

    开发工具:MyEclipse 6....Struts+Spring+Hiberante框架整合的简单登录系统 无需配置任何文件、只需在mysql中创建一个空数据库 如:create database test; 注:mysql数据库用户名:root 密码:root

    hiberante5.0.7安装jar包

    **hibernate5.0.7安装jar包详解** Hibernate是一个强大的Java持久化框架,它为开发者提供了在Java应用程序中管理关系数据库模型的工具。在5.0.7版本中,Hibernate引入了一系列改进和增强,使得它在处理数据库操作时...

    hiberante4.2.3-part2

    hiberante4.2.3-part2

    Hiberante中的五大核心接口.txt

    ### Hibernate中的五大核心接口 #### 一、概述 在Hibernate框架中,存在五大核心接口,它们分别是:`Session`、`SessionFactory`、`Transaction`、`Query` 和 `Configuration`。这些接口对于Hibernate的正常运行至...

    hiberante-4.2.3-part3

    hiberante-4.2.3-part3

    Hiberante3相关文档

    标题“Hiberante3相关文档”表明了主要讨论的是关于Hibernate3这一持久化框架的资料集合,可能涵盖了多个方面,如查询语言、缓存机制以及数据加载策略。 描述中的“Hiberante3_HQL”提示我们将会涉及到Hibernate...

    hiberante查询方式使用详解

    在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它允许开发者使用面向对象的方式来操作数据库,而无需关心底层SQL语句的编写。本文将深入探讨Hibernate的四种主要查询方式:HQL(Hibernate Query...

    hiberante-4.2.3-part4

    hiberante-4.2.3-part4

    springmvc hiberante

    Spring MVC 和 Hibernate 是两个在Java Web开发中广泛使用的框架,它们分别是用于构建MVC(Model-View-Controller)架构的Web应用和管理数据库操作的对象关系映射(ORM)工具。在实际项目中,这两个框架的集成能提供...

    hiberante 代码save方法过程,分析

    hiberante 代码save方法过程,分析

    hiberante3.2纯静源码

    hiberante3.2纯静源码

    Struts2+hiberante+Spring+Extjs+OA办公系统,完整包

    Struts2、Hibernate、Spring、ExtJS 和 OA(Office Automation)办公系统的整合是企业级Java应用开发中的常见架构,这个组合通常被称为SSH2E。这是一个强大的框架集合,用于构建高效、可扩展且易于维护的企业级应用...

    Struts2+Hiberante+ajax+Mysql 三级联动

    总的来说,"Struts2+Hiberante+ajax+Mysql 三级联动"项目展示了如何利用这些技术进行高效的Web开发,特别是在处理多级交互和动态数据展示方面。通过学习和实践这样的项目,开发者可以提升对Java Web开发的理解,尤其...

Global site tag (gtag.js) - Google Analytics