图解Hibernate一级缓存

clipboard.png

// 一级缓存 - 快照
// 快照与一级缓存位于相同的位置,是对一级缓存数据的备份,确保数据库的数据与一级缓存的数据始终保持一致。
// 当一级缓存中的数据被修改并在执行commit提交时,会自动刷新一级缓存并执行update语句,将一级缓存中的数据更新到数据库。
@Test // 快照的演示
public void demo05() {
    Session session = factory.openSession();
    session.beginTransaction();
    User user = (User) session.get(User.class, 1); // -- select
    System.out.println(user);
    user.setUsername("rose2"); // 修改持久态对象内容(一级缓存内容)-- 默认在commit时,将触发update语句(快照)
    session.getTransaction().commit();
    session.close();
}
// refresh 刷新
// refresh 方法确保一级缓存的数据与数据库的数据保持同步。
// 执行refresh方法将会执行select语句查询数据库,并用查询结果覆盖一级缓存中的数据。
@Test // refresh演示
public void demo04() {
    // 刷新
    Session session = factory.openSession();
    session.beginTransaction();
    User user = (User) session.get(User.class, 1); // -- select
    System.out.println(user);
    session.refresh(user); // 将缓存中的数据与数据库中的数据保持一致(会直接查询数据库)
    session.getTransaction().commit();
    session.close();
}
// 一级缓存刷新时机
@Test
public void demo06() {
    // 设置刷新时机
    Session session = factory.openSession();
    session.beginTransaction();

    // 1. 设置刷新模式为MANUAL
    session.setFlushMode(FlushMode.MANUAL);

    User user = (User) session.get(User.class, 1);
    user.setUsername("rose4");

    // 1. 查询所有(注释部分)-- AUTO模式下,在查询之前会先更新,确保一级缓存与数据库一致
    // List<User> allUser = session.createQuery("from User").list();

    // 2. 手动刷新 -- MANUAL模式下,调用flush时将执行update,注意:一级缓存中的数据必须已经被修改
    session.flush();

    // 若为MANUAL模式,在执行commit时不进行自动update
    session.getTransaction().commit();
    session.close();
}
posted @   汉源魂  阅读(14)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示