hibernate学习6_session之clear与flush

1、session的clear()方法

  hibernate从数据库中get或load记录时,或先去session一级缓存中查找对应数据,如果缓存中没有记录,则去对应数据库中查询,

如果有记录则直接从缓存中获取。

    public void testClear() {
        Session session1 = sf.getCurrentSession();
        session1.beginTransaction();
        Student t1 = (Student) session1.get(Student.class, 45);
        //session1.clear();
        Student t2 = (Student) session1.get(Student.class, 45);
        session1.getTransaction().commit();
    }

执行时只会发出一次查询

Hibernate: select student0_.id as id1_0_0_, student0_.age as age2_0_0_, student0_.name as name3_0_0_ from Student student0_ where student0_.id=?

加上session的clear()方法后,会清空当前session缓存,数据库查询两次,如下:

Hibernate: select student0_.id as id1_0_0_, student0_.age as age2_0_0_, student0_.name as name3_0_0_ from Student student0_ where student0_.id=?
Hibernate: select student0_.id as id1_0_0_, student0_.age as age2_0_0_, student0_.name as name3_0_0_ from Student student0_ where student0_.id=?

 

2、session的flush方法

flush方法会强制同步当前session缓存数据至数据库中,如下:

    @Test
    public void testFlush() {
        Session session1 = sf.getCurrentSession();
        session1.beginTransaction();
        Student t1 = (Student) session1.get(Student.class, 45);
        t1.setAge(30);
        t1.setAge(40);
        session1.getTransaction().commit();
    }

此时数据库中load出对应记录后,虽然前后连续更改了两次属性,数据库只执行一次update

Hibernate: update Student set age=?, name=? where id=?

加上flush后:

    public void testFlush() {
        Session session1 = sf.getCurrentSession();
        session1.beginTransaction();
        Student t1 = (Student) session1.get(Student.class, 45);
        t1.setAge(30);
        session1.flush();
        t1.setAge(40);
        session1.getTransaction().commit();
    }

数据库连续执行两次update

Hibernate: update Student set age=?, name=? where id=?
Hibernate: update Student set age=?, name=? where id=?

 

转载于:https://www.cnblogs.com/toDjlPersonnalBlog/p/4257705.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值