`
学会做人
  • 浏览: 120368 次
  • 性别: 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的时候只执行了一条查询oid的sql语句,所以说明,一级缓存被填充过后,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
 
 
三、批量处理

 

 

分享到:
评论

相关推荐

    hibernate查询总结

    hibernate的几种查询方式总结,hql,Criteria等

    Hibernate知识点总结

    ### Hibernate知识点总结 #### 一、Hibernate概述 Hibernate是一个开源的ORM(Object Relational Mapping,对象关系映射)框架,用于Java应用与关系型数据库之间的交互。它通过使用描述对象和数据库之间映射的元...

    hibernate学习总结文档

    2. **读取(Read)**:`get()` 或 `load()` 方法用于根据主键获取对象,`query()` 或 HQL(Hibernate 查询语言)用于执行更复杂的查询。 3. **更新(Update)**:修改对象后,调用 `update()` 或 `merge()` 方法同步...

    Hibernate4总结文档

    《Hibernate4总结文档》 Hibernate4作为一款强大的Java对象关系映射框架,简化了数据库操作,使得开发者可以更专注于业务逻辑而不是数据库层面的细节。本文将深入探讨Hibernate4的配置和使用,帮助开发者更好地理解...

    hibernate文档总结,技术汇总,PDF版的,hibernate简明参考文档

    总结来说,Hibernate是一个强大的ORM框架,它极大地简化了Java应用的数据库操作,提高了开发效率,并提供了高级特性如缓存、事务管理等。通过深入理解和熟练使用Hibernate,开发者可以构建更高效、更易于维护的...

    Hibernate连表查询 Hibernate连表查询

    根据提供的文件信息,我们可以深入探讨Hibernate中的连表查询方法及其应用。下面将详细介绍与标题、描述及部分代码相关的几个核心知识点: ### Hibernate 连表查询基础 Hibernate 是一个开源的对象关系映射(ORM)...

    通用的hibernate查询

    【hibernate查询详解】 Hibernate,作为一款强大的Java对象关系映射(ORM)框架,极大地简化了数据库操作。它允许开发者使用面向对象的方式来处理数据库,从而避免了传统的JDBC编码方式带来的复杂性。本篇文章将...

    Hibernate学习总结.doc

    【Hibernate学习总结】 在软件开发领域,分层思想是一种常见的设计模式,有助于组织代码并分离关注点。三层架构包括数据表现层、业务逻辑层和数据持久层。在Java Web开发中,这一架构的具体实现可以是SUN的桌面应用...

    Hibernate三大类查询总结.doc

    《Hibernate三大类查询总结》 在Java的持久化框架中,Hibernate以其强大的功能和易用性占据了重要地位。在处理数据库查询时,Hibernate提供了三种主要的查询方式:Criteria查询、HQL(Hibernate Query Language)和...

    Hibernate_query查询数据表中的一个字段.

    总结,Hibernate提供多种方式查询数据表中的字段,包括HQL、Criteria API和DetachedCriteria,选择合适的方法取决于具体需求。正确理解和使用Hibernate,能够大大提高Java开发中的数据库操作效率。

    struts+hibernate查询所有记录

    ### Struts+Hibernate查询所有记录 #### 一、概述 在Java Web开发中,Struts与Hibernate是非常流行的框架组合,用于构建复杂的企业级应用。本文将详细介绍如何利用Struts和Hibernate来实现对Oracle数据库中所有...

    Hibernate三大类查询总结

    本文将对Hibernate的三大类查询进行详细总结,包括Cretiria查询、HQL查询以及本地SQL查询。 首先,我们来看Cretiria查询,这是Hibernate提供的一种基于对象的查询方式,具有高度的灵活性和可扩展性。`Criteria`接口...

    Hibernate hql查询语法总结

    本文将对Hibernate HQL查询语法进行总结,涵盖基础查询、属性查询、实例化查询以及查询链接等多个方面。 1. 基础查询: 基础查询是最简单的HQL语句,用于获取所有`Student`对象。例如: ```java from Student ``` ...

    Hibernate 简单 PPT 总结

    【Hibernate 简单 PPT 总结】 Hibernate 是一个流行的开源对象关系映射(ORM)框架,它简化了Java应用程序对数据库的操作。通过提供一套API和元数据,Hibernate允许开发者将业务对象直接映射到数据库表,从而避免了...

    hibernate多表联合查询

    ### Hibernate多表联合查询详解 #### 一、引言 在实际项目开发中,我们经常需要处理复杂的数据库查询,特别是涉及到多个表之间的关联查询。Hibernate作为一款流行的Java持久层框架,提供了一种非常便捷的方式来处理...

    hibernate3学习总结

    【hibernate3学习总结】 Hibernate 是一个流行的 Java ORM(对象关系映射)框架,它允许开发者使用面向对象的方式来操作数据库。在学习 Hibernate 3 时,主要关注以下几个核心知识点: 1. **Hibernate 核心接口**...

    Hibernate学习笔记与总结

    **Hibernate学习笔记与总结** Hibernate 是一款开源的对象关系映射(ORM)框架,它为Java开发者提供了一种在关系数据库上操作对象数据的便捷方式。本文将深入探讨Hibernate的核心概念、配置、实体类、映射文件、...

    Hibernate重点总结

    在本文中,我们将深入探讨Hibernate的关键概念、配置、实体管理、查询语言以及缓存机制。 1. **基本概念** - **对象关系映射(ORM)**: ORM是将数据库表映射为Java类,将SQL语句转换为对象操作的一种技术,简化了...

    hibernate 学习总结.doc

    《Hibernate学习总结》 Hibernate,作为Java领域的一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作,使得开发者可以更加专注于业务逻辑,而非底层的数据访问。以下是对Hibernate核心概念和技术的详细...

    Hibernate的查询方式

    ### Hibernate的查询方式详解 #### 引言 Hibernate作为Java领域中最流行的ORM(Object-Relational Mapping)框架之一,提供了一系列高效、灵活的查询机制,旨在桥接对象模型与关系数据库之间的鸿沟。本文将深入...

Global site tag (gtag.js) - Google Analytics