`

Hibernate查询缓存全面分析

 
阅读更多

这里介绍Hibernate查询缓存对Iterator不起作用,只对List起作用。

缓存分类:
◆一级缓存 Session级
◆二级缓存 SessionFactory级别,JVM级别
◆Hibernate查询缓存不固定(生命周期不固定)

生命周期: 
◆一级缓存 是和 session 会话一致产生一致消失
◆二级缓存 是和 sessionFacotry 一致
◆Hibernate查询缓存 生命周期不固定,当数据库表发生改变,使用Hibernate查询缓存马上消失

使用方法: 
◆一级缓存:这个就不用说了
◆二级缓存:首先拷贝使用Hibernate查询缓存类别.xml到 classpath目录下面,然后到hibernate.cfg.xml里面配置。开启二级缓存(默认开启),定义要使用二级缓存的实体类,然后就是在程序中要显示的指定session。使用二级缓存的类别 有三种,Normal,GET,PUT默认使用的是 Normal即可以写也可以读取二级缓存(这里读写是指的会话Session)
◆Hibernate查询缓存:首先也是到hibernate配置文件中去开启Hibernate查询缓存,然后程序中也要显示的调用方法来开启Hibernate查询缓存eg:query.setCachemodel(true);

缓存的保存对象:
◆一级缓存:缓存实体
◆二级缓存:缓存的也是实体
◆Hibernate查询缓存缓存的是查询出来的实体的部分属性结果集和实体的ID(注意这里不是实体)

缓存的使用对象:
◆一级缓存: 
Load(Lazy加载):首先查找把序列号去和一级缓存匹配是否有,有就直接取出来,如果没有,则发出SQL语句。
Get:也使用一级缓存。
List接口:query.list()不使用一级缓存,每次都要发出SQL eg:(select * from tudent)。
Iterator接口: query.iterate();使用一级缓存。首先是要发出一条SQL来取得ID,eg: select。id from student; 然后把ID拿到缓存中去匹配, 如果有,就直接取,如果没有,就要再发出SQL。如果都没有,将发出N+1条SQL,这就是N+1问题。
◆二级缓存: 都使用了二级缓存。
◆Hibernate查询缓存:对List 和Iterator接口起作用。但是Hibernate查询缓存对Iterator不起作用,只对List起作用。

 

下面我们这种介绍把二级缓存和Hibernate查询缓存结合使用。 
当只是用Hibernate查询缓存而关闭二级缓存的时候: 
第一:如果查询的是部分属性结果集: 那么当第二次查询的时候就不会发出SQL,直接从Hibernate查询缓存中取数据;
第二:如果查询的是实体结果集eg(from Student) ,首先Hibernate查询缓存存放实体的ID,第二次查询的时候就到Hibernate查询缓存中取出ID 一条一条的到数据库查询,这样,将发出N 条SQL造成了SQL泛滥。

当都开启Hibernate查询缓存和二级缓存的时候:
第一:如果查询的是部分属性结果集: 这个和上面只是用Hibernate查询缓存而关闭 二级缓存的时候一致,因为不涉及实体不会用到二级缓存;
第二:如果查询的是实体结果集eg(from Student),首先Hibernate查询缓存存放实体的ID,第二次查询的时候,就到Hibernate查询缓存中取出ID,到二级缓存区找数据,如果有数据,就不会发出SQL;如果都有,一条SQL都不会发出,直接从二级缓存中取数据。
 
总结: 查询缓存的key与HQL,查询参数以及分布参数有关,而且一旦查询涉及到的任何一张表的数据发生了变化,缓存就失效了,所以在生产环境中命中率较低。查询缓存保存的是结果集的id列表,而不是结果集本身 ,命中缓存的时候,会根据id一个一个地先从二级缓存查找 ,找不到再查询数据库。

list()没有使用缓存中的实体对象,因为查询需要查找到所有符合条件的记录,因此必须执行SELECT SQL,来保证查询数据的完整性;而iterate()通过执行SELECT SQL语句来获取满足查询条件的记录的ID,来保证查询数据的完整性

分享到:
评论

相关推荐

    基于Lucene4.6+Solr4.6+S2SH实战开发垂直搜索引擎

    对于实际搜索引擎所涉及的各种核心技术都有全面细致的介绍,除了作为搜索系统核心的网络爬虫、索引系统、排序系统、链接分析及用户分析外,还包括网页反作弊、缓存管理、网页去重技术等实际搜索引擎必须关注的技术,...

    SpringBoot项目球队训练信息管理系统.zip

    技术实现上,后端使用SpringBoot简化开发流程和配置工作,SpringMVC处理Web请求和响应,MyBatis或Hibernate作为ORM工具与MySQL或其他数据库交互。前端可能采用Angular、React或Vue.js等现代JavaScript框架构建用户...

    SpringBoot项目师生健康信息管理系统.zip

    技术实现方面,后端使用SpringBoot来简化开发流程和配置工作,SpringMVC处理Web请求和响应,MyBatis或Hibernate作为ORM工具与MySQL或其他数据库交互。前端可能采用Angular、React或Vue.js等现代JavaScript框架构建...

    java开源包8

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    SpringBoot项目基于springboot搭建的疫情管理系统.zip

    系统的核心功能包括疫情数据的实时采集与分析、感染者追踪与健康管理、疫苗接种情况记录、医疗物资的库存与分配管理、以及公共卫生政策的发布与解读。这些功能帮助政府及时了解疫情发展动态,制定相应防控措施;协助...

    SpringBoot项目基于多维分类的知识管理系统.zip

    系统的核心功能包括文档上传与管理、多维度分类与标签化、智能搜索与筛选、权限控制与共享设置、数据分析与报告生成等。通过这些功能,用户可以方便地上传和整理文档资料,根据内容属性分配多个分类标签,快速查找所...

    JAVA毕业设计之基于springboot的疾病防控综合系统的设计与实现(springboot+mysql)完整源码.zip

    数据分析与报告:对收集的数据进行分析,并生成可视化报告帮助决策者制定策略。 新闻动态:发布相关的疾病防控新闻和公告。 互动社区:为用户提供讨论和交流的平台。 总之,此系统的设计旨在通过集成多项服务和技术...

    java开源包1

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包11

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包2

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包3

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包6

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包5

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包10

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包4

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包7

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    java开源包9

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    SpringBoot项目校园疫情防控系统.zip

    SpringBoot项目校园疫情防控系统是一个...总体来说,SpringBoot项目校园疫情防控系统以其全面的功能、稳定的性能和优秀的用户体验,为学校在疫情期间提供了一个高效的管理和服务平台,有助于保障校园内的公共卫生安全。

    java开源包101

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

    Java资源包01

    同时保持蒸提供全面的支持,无缝集成的IDE(语法着色,代码导航,重构等)的语法和操作代码完全分离。最大限度地减少时间和费用开发自定义的DSL(领域特定语言在Java)要求。 日志服务器 Apache Flume.tar Flume 是...

Global site tag (gtag.js) - Google Analytics