缓存使用

hibernate一级缓存

一级缓存很短和session的生命周期一致,一级缓存也叫session级的缓存或事务级缓存
session中的map来实现

那些方法支持一级缓存:
* get()
* load()
* iterate(查询实体对象)
(select * from 查询普通属性, 不支持)

不支持list(),每次都会发

如何管理一级缓存:
* session.clear(),session.evict()

如何避免一次性大量的实体数据入库导致内存溢出
* 先flush,再clear

如果数据量特别大,考虑采用jdbc实现,如果jdbc也不能满足要求可以考虑采用数据本身的特定导入工具

测试用例:
1个session,先save,再load。 不发
1个session,先load,然后clear,再load。 发 (一级缓存不能取消)
加入1000条数据: session.flush(); session.clear()
------------------------------------------------------------------------------------

hibernate二级缓存

二级缓存也称进程级的缓存或SessionFactory级的缓存,二级缓存可以被所有的session共享
二级缓存的生命周期和SessionFactory的生命周期一致,SessionFactory可以管理二级缓存

二级缓存的配置和使用:
* 将echcache.xml文件拷贝到src下
* 开启二级缓存,修改hibernate.cfg.xml文件
<property name="hibernate.cache.use_second_level_cache">true</property>
* 指定缓存产品提供商,修改hibernate.cfg.xml文件
<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
* 指定那些实体类使用二级缓存(两种方法)
* 在映射文件中采用<cache>标签
* 在hibernate.cfg.xml文件中,采用<class-cache>标签

二级缓存是缓存实体对象的
sessionFactory.evict(), 没有clear();


了解一级缓存和二级缓存的交互:
CacheMode( NORMAL, GET, PUT)
session.setCacheMode

----------------------------------------------------------------------------------

hibernate查询缓存 (实现?)

查询缓存是针对普通属性结果集的缓存
对实体对象的结果集只缓存id (然后再到二级缓存里面找实体对象)

查询缓存的生命周期,当前关联的表发生修改,那么查询缓存生命周期结束
(跟sessionFactory没有关系)

查询缓存的配置和使用:
* 在hibernate.cfg.xml文件中启用查询缓存,如:
<property name="hibernate.cache.use_query_cache">true</property>
* 在程序中必须手动启用查询缓存,如:
query.setCacheable(true); (每次都要有这句)

query.list()

query.iterator() ( 查询缓存对迭代接口不起作用)

query必须完全一样。
查询19-25岁之间, 和查询20-25岁的,不会缓存。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值