`
学会做人
  • 浏览: 121287 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Hibernate查询的几个重要理解

阅读更多

一、hibernate查询

      1、测试list和Iterator与缓存的关系

      1)、在同一session中先迭代再list

       执行的结果是:

Hibernate:

    select

        book0_.BID as col_0_0_

    from

        T_BOOK book0_

Hibernate:

    select

        book0_.BID as BID3_0_,

        book0_.BNAME as BNAME3_0_                 

    from

        T_BOOK book0_

    where

        book0_.BID in (

            ?, ?

        )

java

oracle

Hibernate:

    select

        book0_.BID as BID3_0_,

        book0_.BNAME as BNAME3_0_

    from

        T_BOOK book0_

    where

        book0_.BID in (

            ?, ?

        )

c

.Net

***************************

Hibernate:

    select

        book0_.BID as BID3_,

        book0_.BNAME as BNAME3_

    from

        T_BOOK book0_

java

oracle

c

.Net

 

分析:在先迭代的时候,会查询数据库中的oid在一级缓存中创建一个没有数据的代理对象

,当迭代器调用next()方法的时候,就会根据代理对象的每一个oid查询数据库并填充数据

。当迭代完后,再执行list的时候,list是直接到数据库中查询出oid和数据填充一级缓存

,而没有去迭代过后的一级缓存中取数据,而是直接查询数据库!

 

------------------------------------------------------------------------------

2)、在同一session中先list再迭代

   执行的结果是:Hibernate:

    select

        book0_.BID as BID3_,

        book0_.BNAME as BNAME3_

    from

        T_BOOK book0_

java

oracle

c

.Net

***************************

Hibernate:

    select

        book0_.BID as col_0_0_

    from

        T_BOOK book0_

java

oracle

 

 

分析:

   在先list的时候,直接去查询了数据库,并且把oid和数据填充到了一级缓存中去了

;再list完后。继续测试Iterator的时候只执行了一条查询oidsql语句,所以说明,一级缓存被填充过后,Iterator时就不用创建代理,而是直接将数据取出。

 

------------------------------------------------------------------------------

3)在同一session中执行两次list

 

查询结果是:Hibernate:

   select

        book0_.BID as BID3_,

        book0_.BNAME as BNAME3_

    from

        T_BOOK book0_

java

oracle

c

.Net

***************************

Hibernate:

    select

        book0_.BID as BID3_,

        book0_.BNAME as BNAME3_

    from

        T_BOOK book0_

java

oracle

c

.Net

分析:两条sql都是一样的,说明在第一次执行list 的时候填充了oid和数据到一级缓存中;

但是执行第二次list的时候还是打印了sql说明list填充数据到一级缓存中并没有用!

而是重写到数据库中查询数据!

 

 

 

 

总结:

       get 和 load

 

A、get

1、在一级缓存中找Book 的代理Proxy

2、如果找不到就到数据库中去找

3、若数据中没有数据则返回null(这个与一级缓存无关)

4、如果数据库中有数据在一级缓存中就会创建代理对象

(是填充了数据的代理)

 

 

B、load

1、如果在一级缓存中找,如果找到了就什么都不做了

2、如果找不到的话就创建代理并且设置OID(与数据库无关,只跟一级缓存有关)

3、无论是对代理对象的任何方法,都会触发查找数据库(例如在代理中调用tostring)

 

 

 

     list 和 Iterator

 

  A、list会直接查询数据库把oid和数据填充到一级缓存中类似于get;但是查出来到缓存中后却没有用

  B、Iterator会直接先查询oid创建没有数据的代理对象,当调用next()方法的时候才会根据第一个oid来查询数据库得到数据填充

  C、无论在list和Iterator过后,再执行load的话,都不会打印load的sql语句

 

二、hibernate性能优化

 

1、延迟加载

  A、当我在Book.bhm.xml配置文件中的class里面将lazy设置成false时、(在不调用任何方法的情况下)会打印出查询数据库的sql

 

这说明:如果将lazy设置成false,一旦load的时候就会将oid和数据一起装载,不会延迟

 

 

2、预先装载

 

1.利用Hql的left join fetch 来实现

 

2、利用条件查询setFetchMode("多方的类",FetchMode.JOIN)

 

3、在配置文件中写将fetch设置为join

 

 

分享到:
评论

相关推荐

    HQL是hibernate自己的一套查询

    通过上述介绍可以看出,HQL作为一种面向对象的查询语言,在Hibernate框架中扮演着非常重要的角色。它不仅简化了数据访问层的开发工作,而且还提高了代码的可读性和可维护性。同时,Hibernate还提供了多种查询方式供...

    hibernate 影院信息查询

    系统主要包含以下几个模块: 1. 用户管理:用户登录、注册功能,以及权限验证。这部分可能涉及到Spring Security或者自定义的身份验证机制,用于确保用户安全访问系统。 2. 影院信息:存储和查询各个影院的基本...

    hibernateHQL关联查询

    在理解Hibernate HQL关联查询之前,我们需要先回顾一下数据库表连接的基本概念及其分类。数据库表连接主要分为以下几种: 1. **内连接(Inner Join)**:只返回两个表中满足连接条件的记录。如果某条记录在另一个表...

    hibernate查询缓存1

    当我们在Hibernate中进行查询时,主要有以下几种方式: 1. **主键查询**:通过`get()`或`load()`方法根据主键获取对象。`get()`方法会立即从数据库中获取数据,而`load()`方法则返回代理对象,直到实际访问属性时才...

    Hibernate各种查询:联表查询 分页查询 位置参数查询(?) 占位符查询(冒号查询) 统计查询

    本篇文章将详细解析Hibernate中的几种主要查询方式,包括联表查询、分页查询、位置参数查询、占位符查询(冒号查询)以及统计查询,这些都是在实际开发中非常常见的需求。 首先,我们来看**联表查询**。在Hibernate...

    Hibernate常用的jar包和两个配置文件

    在Java Web开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它极大地简化了数据库操作,使得开发者可以使用面向对象的方式来处理数据库事务。本篇文章将深入探讨Hibernate框架中常用的jar包以及两个核心...

    hibernate+struts实现数据库查询的例子

    整合`Hibernate`和`Struts2`的过程通常包括以下几个步骤: 1. **环境配置**:首先需要在项目中引入Hibernate和Struts2的依赖库,如JAR包或Maven依赖。 2. **创建实体类**:根据数据库表结构,定义Java实体类,并...

    Hibernate生产SQL语句

    模仿Hibernate生成SQL语句,我们可以从以下几个方面入手: 1. **实体类(Entity)与表映射**:Hibernate通过`@Entity`注解定义一个Java类为数据库中的表,`@Table`注解指定对应的表名。实体类的属性对应表中的列,`...

    Hibernate中文文档+hibernate annotation +distribution

    在使用Hibernate进行数据库操作时,有几个关键概念值得深入理解: 1. 实体(Entity):在Hibernate中,实体对应数据库中的表,通过@Entity注解声明。 2. 映射(Mapping):实体和数据库表之间的关系通过XML或注解...

    Hibernate映射导致的几个异常

    标题与描述概述的知识点主要集中在Hibernate映射过程中可能遇到的各种异常情况,这涉及到数据库与对象模型之间的映射问题,以及Hibernate...理解和掌握这些异常的原因及其解决方法对于高效使用Hibernate框架至关重要。

    Hibernate帮助文档

    文档中可能涵盖了以下几个关键知识点: 1. **配置**: Hibernate的配置文件(通常是hibernate.cfg.xml)是项目启动的基础,它包含了数据库连接信息、方言设置、缓存策略等。了解如何正确配置这些参数对使用...

    Hibernate-二级缓存总结 开发技术 - Java.zip

    二级缓存分为几个类别,包括查询缓存、集合缓存、实体缓存等。查询缓存会缓存SQL查询的结果,避免重复执行相同的查询;集合缓存存储关联的集合数据,减少加载关联对象时的数据库访问;实体缓存则是缓存单个实体对象...

    hibernate_third项目源码

    在这个项目中,我们将探讨以下几个核心知识点: 1. **Hibernate配置**:首先,你需要了解Hibernate的配置文件(hibernate.cfg.xml),其中包含了数据库连接信息、方言设置、缓存策略等关键配置。理解这些参数如何...

    Hibernate\hibernate3.2官方中文参考手册PDF

    9. **实体生命周期**:Hibernate定义了几个关键的实体状态,如瞬时态、持久态、脱管态和临时态,理解这些状态对于理解对象的管理至关重要。 10. **实体的级联操作**:级联操作允许在一个操作中处理关联的对象,例如...

    hibernate 常用核心包

    在 Hibernate 中,以下几个核心包是至关重要的: 1. **hibernate-core**: 这是 Hibernate 的核心库,包含 ORM 功能的主要实现。它提供了实体管理、会话管理、查询服务等功能。例如,`org.hibernate.Session` 类是与...

    hibernate项目源代码

    在Hibernate项目中,通常会涉及以下几个核心知识点: 1. **配置文件**:`hibernate.cfg.xml`是Hibernate的主配置文件,其中包含了数据库连接信息、JDBC驱动、事务管理器设置等。学习者应了解如何配置这些参数以确保...

    hibernate-core 核心jar包

    在Hibernate-Core中,主要包含以下几个关键模块和概念: 1. **Session接口**:它是Hibernate的主要工作接口,提供了对数据库的操作方法,如保存、更新、删除对象,以及执行SQL查询。Session管理了对象的状态,并...

    Hibernate3.2.5.jar

    在Hibernate 3.2.5版本中,有以下几个重要的知识点: 1. **实体管理**:Hibernate的核心功能之一就是实体管理,它允许开发者定义Java类作为数据库表的映射,并通过注解或XML配置文件定义这些类的字段与数据库列的...

    hibernate-release-5.4.25.Final_Hibernate5.4.25_hibernate所需jar包_源

    配置Hibernate主要涉及以下几个方面: - 配置文件:通常为`hibernate.cfg.xml`,定义数据库连接信息、实体类扫描路径、缓存策略等。 - 实体类:使用Java类表示数据库表,通过注解声明字段与表列的映射关系。 - ...

Global site tag (gtag.js) - Google Analytics