hibernate delete()、update()与createQuery的相同功能语句的缓存差异

学到hibernate缓存 一直比较苦恼 搞得有点头疼,今天终于发现差别了。
首先说在session缓存中,使用session.delete()、session.update()、session.save()其主要功能是改变实体对象的状态(游离、删除、持久化状态等),不完全是操纵数据库,其中save是把临时对象变为持久化对象,当session缓存被清理之前(亲测 save先是存储在缓存中,在事务提交后插入数据库,上面的加上saveOrUpdate等都是先更新session缓存然后在提交缓存清理前操纵数据库),向数据库发出insert请求。
需要注意的是:这些更新、删除操作都是同步到session缓存中(session缓存会实时更新);但是如果使用Session.createQuery(删除语句或更新语句)时,进行的操作是不会通知session缓存的。

所有的查询操作都会把数据放进缓存,这里所说的一级和二级缓存,只是对get、load而言并且使用OID(主键)查找对象才会被缓存(一级二级缓存),对于query需要额外设置setCacheable(true)此时是把HQL语句作为key值与结果集对应存储,所以必须HQL查询语句一样否则即使存在子集也必须重新查询。使用iterator迭代是根据id(OID)一个一个查询(为了使用缓存),第二次查询则可以使用缓存中存在的部分对象,使用缓存效率不高。
对于二级缓存 query使用update和delete HQL语句时会自动使二级缓存数据失效,下次使用重新查询。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值