hibernate mysql flush_hibernate中flush()、refresh()、clear()缓存操作

b5387bcc6612653dc1e8f276629393bb.png

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~分割线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

flush():使数据库中的对象和session缓存中的对象的状态保持一致。为了保持一致,则可能发送对应的sql语句(若缓存中的对象和数据库中的对象一样则不发送sql语句)。

1、在transaction的commit()方法中:先调用session的flush方法,再提交事务。

2、flush方法可能会发送sql语句,但不会提交事务。

3、注意:在未提交事务或显示的调用session.flush()方法之前,也有可能会进行flush()操作。

1)在执行HQL或QBC查询,会先进行flush()操作以得到数据表的最新的记录。

2)若记录的id是由底层数据库使用自增的方式生成的,则在save()方法后,就会立即发送insert语句,因为save()方法后必须保证对象的id是存在的。

commit()和flush的区别:flush执行一系列sql语句但不提交事务;commit()先调用flush()方法再提交事务,提交事务意味着对数据库操作永久保存下来。

refresh():会强制发送select语句,以使session缓存中对象的状态和数据表中对应的记录保持一致。该方法的有效性需要配置事务的隔离级别为read commited(读已提交),在hibernate.cfg.xml文件中配置2

clear():清理缓存。

参考:https://blog.csdn.net/qq_27739989/article/details/51407351。图片:https://blog.csdn.net/chuck_kui/article/details/51531089。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值