一、概述

  • 什么是缓存:

    • 缓存将数据库/硬盘上文件中数据,放入到缓存中(就是内存中一块空间).当再次使用的使用,可以直接从内存中获取.
  • 缓存的好处:
    • 提升程序运行的效率.缓存技术是Hibernate的一个优化的手段.
  • Hibernate分成两个基本的缓存
    • 一级缓存:Session级别的缓存.一级缓存与session的生命周期一致.自带的.不可卸载.
    • 二级缓存:SessionFactory级别的缓存.不是自带的.
  • 在 Session 接口的实现中包含一系列的 Java 集合, 这些 Java 集合构成了 Session 缓存. 只要 Session 实例没有结束生命周期, 存放在它缓存中的对象也不会结束生命周期.

二、证明Hibernate的一级缓存的存在

@Test
// 证明一级缓存的存在
public void demo3(){
// 1.创建Session
Session session = HibernateUtils.openSession();
// 2.开启事务
Transaction tx = session.beginTransaction();
// save方法可以向一级缓存中存放数据的.
/*Book book = new Book();
book.setName("JQuery开发");
book.setAuthor("张XX");
book.setPrice(45d); Integer id = (Integer) session.save(book); Book book2 = (Book) session.get(Book.class, id); System.out.println(book2);*/ // 分别用get执行两次查询.
Book book1 = (Book) session.get(Book.class, 1);// 马上发生SQL去查询
System.out.println(book1); Book book2 = (Book) session.get(Book.class, 1);// 不发生SQL,因为使用一级缓存的数据
System.out.println(book2); // 3.提交事务
tx.commit();
// 4.关闭资源
session.close();
}

三、一级缓存中快照区

@Test
// 深入理解一级缓存结构:快照区:
public void demo4(){
// 1.创建Session
Session session = HibernateUtils.openSession();
// 2.开启事务
Transaction tx = session.beginTransaction(); // 获得一个持久态的对象.
Book book = (Book) session.get(Book.class, 1);
book.setName("Spring3开发"); // 3.提交事务
tx.commit();
// 4.关闭资源
session.close();
}
  • 结论:向一级缓存存入数据的时候,放入一级缓存区和一级缓存快照区,当更新了一级缓存的数据的时候,事务一旦提交,比对一级缓存和快照区,如果数据一致,不更新,如果数据不一致,自动更新数据库.

四、管理一级缓存

  • 一级缓存是与session的生命周期相关的.session生命周期结束,一级缓存便销毁了
  • clear()/evict()/flush()/refresh():管理一级缓存.
  • clear():清空一级缓存中所有的对象.
  • evict(Object obj) :清空一级缓存中某个对象.
  • flush():刷出缓存.
  • refresh(Object obj):将快照区的数据重新覆盖了一级缓存的数据.

五、Hibernate一级缓存的刷出时机

  • FlushMode常量

    • ALWAYS:每次查询的时候都会刷出.手动调用flush.事务提交的时候.
    • AUTO:默认值.有些查询会刷出.手动调用flush.事务提交的时候.
    • COMMIT:在事务提交的时候,手动调用flush的时候.
    • MANUAL:只有在手动调用flush才会刷出.
  • 严格程度:MANUAL > COMMIT > AUTO > ALWAYS

六、操作持久化对象的方法

  • 1.save()

    • 保存一条记录:将瞬时态对象转成持久态对象.
  • 2.update()
    • 更新一条记录:将脱管态对象转成持久态对象.
    • 在标签上设置select-before-update="true"在更新之前先去查询
  • 3.saveOrUpdate()
    • 根据对象状态的不同执行不同的save获得update方法.
    • 如果对象是一个瞬时态对象:执行save操作.
    • 如果对象是一个脱管态对象:执行update操作.
    • 设置id不存在,就会报错,可以在上设置一个unsaved-value=”-1”,执行保存的操作.
  • 4.delete()
    • 将持久态对象转成瞬时态.
  • 5.get()/load()
    • 获得一个持久态对象.

【Hibernate】一级缓存的更多相关文章

  1. hibernate一级缓存

    理解 Hibernate 一级缓存 Hibernate 一级缓存默认是打开,不需要任何的配置.实际上,你无法强制禁止它的使用. 如果你理解了一级缓存实际上和会话是关联的,就很容易理解一级缓存.总所周知 ...

  2. Hibernate一级缓存(基于查询分析)

    首先我们应该弄清什么是hibernate缓存:hibernate缓存是指为了降低应用程序对物理数据源的访问频次,从而提高应用程序的运行性能的一种策略.我们要将这个跟计算机内存或者cpu的缓存区分开. ...

  3. hibernate一级缓存及对象的状态

    hibernate中实体类对象的状态 在hibernate中实体类对象有三种状态 (1)瞬时态(临时态) 瞬时态:即我们自己创建一个对象,还没有保存到数据库就叫临时态,其实也可以说是对像没有id值,跟 ...

  4. Hibernate一级缓存(补)

    ------------------siwuxie095                                 什么是缓存         缓存是介于应用程序和永久性数据存储源(如:硬盘上的 ...

  5. Hibernate一级缓存测试分析

    Hibernate 一级缓存测试分析 Hibernate的一级缓存就是指Session缓存,此Session非http的session会话技术,可以理解为JDBC的Connection,连接会话,Se ...

  6. 转载 hibernate一级缓存和二级缓存的区别

    文章来源:http://blog.csdn.net/defonds/article/details/2308972     hibernate一级缓存和二级缓存的区别 缓存是介于应用程序和物理数据源之 ...

  7. Hibernate一级缓存和三种状态

    Hibernate一级缓存又称session缓存,生命周期很短,跟session生命周期相同. 三种状态:1.transient(瞬时态):刚new出来的对象,既不在数据库中,也不在session管理 ...

  8. hibernate一级缓存的源码初窥

    hibernate的一级缓存的存在使得hibernate可以在操作实体化对象的时候减少对于数据库的访问.hibernate的一级缓存实际上就是指的session缓存,它的生命周期和session相同. ...

  9. Hibernate 一级缓存的陷阱

    最近公司的应用经常报OOM,一开始我以为是公司业务数据太多,导致内存不够,所以只是简单的把容器的内存加大.撑了几天后这个错仍然被报出来.后来我仔 细分析过项目代码后,没有发现有任何引起内存泄漏的地方. ...

  10. Hibernate <一级缓存>

    Hibernate缓存分为三级: 一级缓存:基于事务级别(内存)的缓存,也可以成为session级别缓存 二级缓存:依赖于第三方,当请求一个对象时,先在缓存里面查找,如果没有就执行查询语句 查询缓存: ...

随机推荐

  1. LeetCode_160. Intersection of Two Linked Lists

    160. Intersection of Two Linked Lists Easy Write a program to find the node at which the intersectio ...

  2. navigationBarTitleText

    想修改整个程序的导航栏,在app.json 文件 修改 "window": { "backgroundTextStyle": "light" ...

  3. Java API操作Hadoop可能会遇到的问题以及解决办法

    https://www.zifangsky.cn/1292.html Could not locate Hadoop executable: xxx\bin\winutils.exe   1 2 3 ...

  4. 【leetcode_easy】590. N-ary Tree Postorder Traversal

    problem 590. N-ary Tree Postorder Traversal 参考 1. Leetcode_easy_590. N-ary Tree Postorder Traversal; ...

  5. 无缝轮播 css3

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. 第十七章 OAuth2集成——《跟我学Shiro》

    目录贴:跟我学Shiro目录贴 目前很多开放平台如新浪微博开放平台都在使用提供开放API接口供开发者使用,随之带来了第三方应用要到开放平台进行授权的问题,OAuth就是干这个的,OAuth2是OAut ...

  7. boost::bind四种应用场景的例子

        普通函数 int f( int a, int b ){return a + b;}boost::bind( f, _1, 9 )( 1 ) 成员函数 struct demo{int f( in ...

  8. Mongodb: com.mongodb.MongoSocketReadException: Prematurely reached end of stream

    saveLocationInfo errorcom.mongodb.MongoSocketReadException: Prematurely reached end of stream at com ...

  9. 结合 Nginx 谈谈 Http 状态码

    [Http状态码简介] [百度百科]HTTP状态码(英语:HTTP Status Code)是用以表示网页服务器超文本传输协议响应状态的3位数字代码.它由 RFC 2616 规范定义的,并得到 RFC ...

  10. [转帖]阿里云VS腾讯云 谁才是中国未来的云计算之王?

    阿里云VS腾讯云 谁才是中国未来的云计算之王? https://www.qianzhan.com/analyst/detail/220/191008-f05009f6.html 吴小燕• 2019-1 ...