Hibernate之刷新点与同步点
刷新与刷新点
刷新:对session缓存数据的刷新,也就是对堆内存数据的更新
刷新点:就是执行刷新操作的时间点,也就是当程序中出现了Update或者delete操作时,Hibernate不会执行相应的SQL语句,而是要等到了刷新点才执行
同步与同步点
**同步:就是将session数据同步到数据库
同步点:执行同同步操作的时间点**
session的同步点只有一个——事务的提交
session中数据的改变不会立即与数据库同步,而是要在执行commit操作后再同步
session的刷新点主要有三个
1)、执行Query查询
2)、session.fulsh()操作
3)、执行事务的提交
看看过程
测试代码
public void test(){
//获取session 对象
Session session = HbnUtils.getSession();
//开启事务
session.beginTransaction();
try {
//获取一个对象
Student student = session.get(Student.class, 1);
//执行delete操作
session.delete(student);
//制造一个刷新点
session.createQuery("from Student").list();
//提交事务
//session.getTransaction().commit();
} catch (Exception e) {
//回滚事务
session.getTransaction().rollback();
e.printStackTrace();
}
}
在get方法处设置一个断点
可以看到,执行完delete操作后,Hibernate并没有立刻执行相应的SQL语句,继续下一步
可以看到再到达刷新点时,delete才得以执行,继续执行完程序
查看数据库发现数据并没有改变(因为commit被注释了),也就是数据并没有同步到数据中
需要注意的是:并不是所有操作到了刷新点都会执行相应的SQL语句,当执行的是update操作时,到了刷新点是否执行Update SQL语句取决于当前数据与快照数据是否一致,如果不一致,就会执行Update语句,如果一致即使是到了刷新点也不会执行Update语句