`
学会做人
  • 浏览: 118741 次
  • 性别: 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 hql查询语法总结

    Hibernate hql查询语法总结 Hibernate hql查询语法总结

    hibernate多表联合查询

    hibernate多表联合查询实例,很经典的查询语句和总结.

    Hibernate三大类查询总结.doc

    Hibernate目前总共分为三大类查询:cretiria,hql,本地sql 详细介绍着三种方式的区别和用法

    Hibernate三大类查询总结

    第一:关于cretiria的查询 第二:HQL查询 第三,本地SQL查询

    hibernate中的查询方式

    hibernate中,对其中的查询方式进行总结,包括hql查询,条件查询,sql查询等

    Hibernate HQL查询语句总结.docx

    Hibernate HQL查询语句总结.docx 网络下载的

    J2EE系统之-hibernate学习总结

    4、使数据格式,便于管理和查询 对象持久化的途径: 1、对象序列化:不适合大量数据操作 2、关系型数据库 企业计算的需求: 1、海量数据的存储 2、大规模的查询,报表 3、稳固的数据完整性...

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

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

    hibernate多表查询详解

    该源代码配了了解释,针对hibernate中多表查询的多种形式进行了总结,很有价值,有Object[]形式的查询,也有对象方式的查询 也有集合list形式的查询,

    hibernate查询

    hibernate查询,结合hibernate的模糊查询,等其他总结。

    hibernate的配置使用和各种查询

    根据自己学习总结的一些hibernate资料,包括全面介绍关系配置和各种查询,都有详细的说明。还有自己写的一些小dome。希望对初学者有帮助!

    hibernate缓存总结

    SHH两年工作经验:hibernate缓存总结和优化

    Hibernate-HQL-查询-Query资料

    Hibernate HQL 查询 Query 资料 3个word总结的资料。

    Hibernate_二级缓存总结

    hibernate 查询缓存 (hibernate 默认是关闭的 ) 查询缓存是针对普通属性结果集的缓存 对实体对象的结果集只缓存 id 查询缓存的生命周期,当前关联的表发生修改,那么查询缓存生命周期结束 查询缓存的配置和使用...

    Hibernate 查询方式总结

    1. get() and load() Java代码 session.get(Clazz, id); session.load(Clazz, id); session.get(Clazz, id); session.load(Clazz, id); 说明: load()与get()的区别 请注意如果没有匹配的数据库记录,load()方法可能...

    Hibernate的Criteria用法总结.doc

    Hibernate中Criteria的完整用法 Criteria 是一个完全面向对象,可扩展的条件查询API,通过它完全不需要考虑数据库底层如何实现、SQL语句如何...

    Hibernate+中文文档

    14. HQL: Hibernate查询语言 14.1. 大小写敏感性问题 14.2. from子句 14.3. 关联(Association)与连接(Join) 14.4. join 语法的形式 14.5. select子句 14.6. 聚集函数 14.7. 多态查询 14.8. where子句 14.9....

    Hibernate注解总结

    方便 Hibernate 注解的查询使用,包含了常用的注解及其属性值和说明!

    hibernate总结

    Hibernate的检索方式:(查询/加载) 1. 通过OID加载 session.get(Users.class, 1); * 2. 通过HQL/SQL 检索 hibernate query language (面向对象的查询语言) * a) 不再操纵表,它操纵的是持久化类的对象 b) 面向...

Global site tag (gtag.js) - Google Analytics