HibenateMinute(三)

本文深入探讨Hibernate缓存机制,解析一级缓存与二级缓存的工作原理及应用场景,并介绍缓存同步策略与配置方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

hiberate 一般而言,ORM的数据包含如下几个

1.       事务级缓存(Transcation Layer Cache)

2.       应用级/进程级缓存(Application/Process Layer Cache)

3.        分布式缓存(Cluster Layer Cache)

Hibernate数据缓存(Cache)分为两个层次,以Hibernate语义加以区分,

可分为:

1.       内部缓存(Session Level,也称为一级缓存)

2.       二级缓存(SessionFactory Level,也称为二级缓存)

Hibernate中,缓存将在以下情况中发挥作用:

1.       通过id[主键]加载数据时每个实体唯一的OID

2.       延迟加载

 

@ Cache缓存:

1.        Session level (一级缓存):

         主要作用于:主键获得的数据, 延迟初始化(Lazy Initialization)起作用.

         状态依赖于:Session的建立而建立(销毁而销毁).// Session是个Map容器!

         清除Session对象:  Session.Save()也是交给Session level来管理,很多的时候会发生OutOfMemoryError异常,所以要及时发送给数据库session.flush(),清除session.clear()或session.evict(user1);

        SQL ServerOracle, Hibernat定属性hibernate.jdbc.batch_size多少数据发送

 <hibernate-configuration> <session-factory>

<property name="hibernate.jdbc.batch_size">100

</property> // MySQL是不支持的,

</session-factory>

<hibernate-configuration>

 

2.     SessionFactory level(二级缓存)

       二级缓存是SessionFactory级别的全局缓存, 是进程范围或者集群范围的缓存, 存放的对象的松散数据,可能出现并发问题, 需要采用适当的并发访问策略,该策略为被缓存的数据提供了事务隔离级别。缓存适配器用于把具体的缓存实现软件与Hibernate集成。第二级缓存是可选的,可以在每个类或每个集合的粒度上配置第二级缓存。

           可以使用不同的缓存类库,比如ehcache、oscache等,需要设置hibernate.cache.provider_class,之后,需要在映射文件中指定各个映射实体(以及collection)的缓存同步策略。Hibernate提供了一下4种内置的缓存同步策略:
      1. read-only
         只读。对于不会发生改变的数据,可使用只读型缓存。
      2. nonstrict-read-write
         如果程序对并发访问下的数据同步要求不是非常严格,且数据更新操作频率较低,可以采用本选项,获得较好的性能。
      3. read-write
         严格可读写缓存。基于时间戳判定机制,实现了“read committed”事务隔离等级。可用于对数据同步要求严格的情况,但不支持分布式缓存。这也是实际应用中使用最多的同步策略。
      4. transactional
         事务型缓存,必须运行在JTA事务环境中。

如果使用查询缓存,加上hibernate.cache.use_query_cache=true,只有当经常使用同样的参数进行查询时,这才会有些用处。该设置将会创建两个缓存区域 - 一个用于保存查询结果集(org.hibernate.cache.StandardQueryCache); 另一个则用于保存最近查询的一系列表的时间戳(org.hibernate.cache.UpdateTimestampsCache)。 请注意:在查询缓存中,它并不缓存结果集中所包含的实体的确切状态;它只缓存这些实体的标识符属性的值、以及各值类型的结果。 所以查询缓存通常会和二级缓存一起使用。 绝大多数的查询并不能从查询缓存中受益,所以Hibernate默认是不进行查询缓存的。如若需要进行缓存,请调用 Query.setCacheable(true)方法。这个调用会让查询在执行过程中时先从缓存中查找结果, 并将自己的结果集放到缓存中去。

Hibernate的二级缓存策略的一般程如下:

 

1) 条件查询的时候,总是发出一条select * from table_name where …. (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象。

2) 把获得的所有数据对象根据ID放入到第二级缓存中。

3) 当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查;查不到,如果配置了二级缓存,那么从二级缓存中查;查不到,再查询数据库,把结果按照ID放入到缓存。

4) 删除、更新、增加数据的时候,同时更新缓存。

  Hibernate的二级缓存策略,是针对于ID查询的缓存策略,对于条件查询则毫无作用。为此,Hibernate提供了针对条件查询的Query缓存。

 

HibernateQuery存策略的程如下:

 

1) Hibernate首先根据些信息成一个Query KeyQuery Key包括条件查询求一般信息:SQL, SQL需要的参数,记录(起始位置rowStart,最大记录个数maxRows),等。

2) Hibernate根据Query Key到Query存中对应果列表。如果存在,那返回果列表;如果不存在,查询数据果列表,把整个果列表根据Query Key放入到Query存中。

3) Query Key中的SQL及到一些表名,如果些表的任何数据生修改、除、增加等操作,些相Query Key都要从存中清空。

 

么样的数据适合存放到第二级缓存中?

1 很少被修改的数据

2 不是很重要的数据,允的数据

3 不会被并发访问的数据

4 参考数据

不适合存放到第二级缓存的数据?

1 常被修改的数据

2 财务数据,绝对不允

3 与其他用共享的数据

,当save()、update()或 saveOrUpdate()方法传递一个,或使用load()、 get()、list()、iterate() 或scroll()方法得一个, 该对象都将被加入到Session的内部存中。

当随后flush()方法被象的状会和数据取得同。 如果你不希望此同操作生,或者你正理大量象、需要有效管理内存,你可以evict() 方法,从一级缓存中去掉象及其集合。如若要把所有的象从session存中底清除,需要Session.clear(),不最好先Session.flush()

SessionFactory也提供了移除存的方法,些方法是:
sessionFactory.evict(Cat.class, catId); //evict a particular Cat
sessionFactory.evict(Cat.class);  //evict all Cats
sessionFactory.evictCollection("Cat.kittens", catId); //evict a particular collection of kittens
sessionFactory.evictCollection("Cat.kittens"); //evict all kitten collections

 

于事物管理的确定:

 hibernate.cfg.xml :

   <hibernate-configuration>

    <session-factory>

        ....

        <!-- 設定事務管理的工廠類 -->
        <property name="hibernate.transaction.factory_class">

            org.hibernate.transaction.JDBCTransactionFactory  </property>

</hibernate-configuration>

try {

    session = sessionFactory.openSession();  

    Transaction tx = session.beginTransaction();

    ....

    tx.commit();  // 必須commit才會更新資料庫

} catch(HibernateException e) {

    tx.rollback();

}

Postil: 对于MySQL处理机制要建立事物表类型的

类型的对照表:

Java

Hibernate

SQL

byte、java.lang.Byte

byte

TINYINT

short、java.lang.Short

short

SMALLINT

int、java.lang.Integer

integer

INGEGER

long、java.lang.Long

long

BIGINT

float、java.lang.Float

float

FLOAT

double、java.lang.Double

double

DOUBLE

java.math.BigDecimal

big_decimal

NUMERIC

char、java.lang.Character

character

CHAR(1)

boolean、java.lang.Boolean

boolean

BIT

java.lang.String

string

VARCHAR

boolean、java.lang.Boolean

yes_no

CHAR(1)('Y'或'N')

boolean、java.lang.Boolean

true_false

CHAR(1)('Y'或'N')

java.util.Date、java.sql.Date

date

DATE

java.util.Date、java.sql.Time

time

TIME

java.util.Date、java.sql.Timestamp

timestamp

TIMESTAMP

java.util.Calendar

calendar

TIMESTAMP

java.util.Calendar

calendar_date

DATE

byte[]

binary

VARBINARY、BLOB

java.lang.String

text

CLOB

java.io.Serializable

serializable

VARBINARY、BLOB

java.sql.Clob

clob

CLOB

java.sql.Blob

blob

BLOB

java.lang.Class

class

VARCHAR

java.util.Locale

locale

VARCHAR

java.util.TimeZone

timezone

VARCHAR

java.util.Currency

currency

VARCHAR

内容概要:该论文探讨了一种基于粒子群优化(PSO)的STAR-RIS辅助NOMA无线通信网络优化方法。STAR-RIS作为一种新型可重构智能表面,能同时反射和传输信号,与传统仅能反射的RIS不同。结合NOMA技术,STAR-RIS可以提升覆盖范围、用户容量和频谱效率。针对STAR-RIS元素众多导致获取完整信道状态信息(CSI)开销大的问题,作者提出一种在不依赖完整CSI的情况下,联合优化功率分配、基站波束成形以及STAR-RIS的传输和反射波束成形向量的方法,以最大化总可实现速率并确保每个用户的最低速率要求。仿真结果显示,该方案优于STAR-RIS辅助的OMA系统。 适合人群:具备一定无线通信理论基础、对智能反射面技术和非正交多址接入技术感兴趣的科研人员和工程师。 使用场景及目标:①适用于希望深入了解STAR-RIS与NOMA结合的研究者;②为解决无线通信中频谱资源紧张、提高系统性能提供新的思路和技术手段;③帮助理解PSO算法在无线通信优化问题中的应用。 其他说明:文中提供了详细的Python代码实现,涵盖系统参数设置、信道建模、速率计算、目标函数定义、约束条件设定、主优化函数设计及结果可视化等环节,便于读者理解和复现实验结果。此外,文章还对比了PSO与其他优化算法(如DDPG)的区别,强调了PSO在不需要显式CSI估计方面的优势。
内容概要:本文档详尽介绍了人机交互与网页开发课程作业的复现过程,涵盖内容开发、UI原型设计、网站开发、多保真度原型设计、创意工具和技术应用、网站必备功能实现、学术诚信与提交指南、评分标准等方面。具体包括用户需求分析、低保真和高保真原型设计、前端和后端开发示例、数据库设计、可用性测试、故事板设计、响应式设计、3D交互元素创建、备份工具、管理面板、原创性检查系统、标题页生成器、评分标准检查表、学术写作质量分析器、评分标准映射系统、项目质量保证检查表、低分项目诊断与改进系统、评分标准转换工具以及学术诚信教育模块。每个部分都提供了详细的代码实现和中文解释,确保项目符合课程要求并达到较高的评分标准。 适合人群:适用于正在学习人机交互与网页开发课程的学生,尤其是需要完成类似课程作业的人群;同时也适合希望深入了解Web开发全流程的专业人士。 使用场景及目标:①帮助学生理解并完成课程作业,包括从需求分析到最终提交的全过程;②为开发者提供实际项目开发中的技术参考,如前后端开发、数据库设计、响应式设计等;③确保项目的学术诚信,提供原创性检查和学术写作质量分析工具;④帮助学生理解评分标准,提供详细的评分映射和改进建议;⑤提供学术诚信教育,确保学生了解并遵守学术规范。 其他说明:本文档不仅提供了技术实现的代码示例,还涵盖了项目管理和学术诚信方面的内容,确保学生能够在技术、管理和学术个方面都能得到全面提升。此外,文档还提供了多种工具和系统,帮助学生更好地准备和优化他们的课程作业,从而获得更高的评分。
标题SpringBoot智能垃圾分类系统研究AI更换标题第1章引言介绍智能垃圾分类系统的研究背景、意义、现状以及论文的研究方法和创新点。1.1研究背景与意义阐述智能垃圾分类系统的重要性及其在现实中的应用价值。1.2国内外研究现状概述国内外在智能垃圾分类系统方面的研究进展及成果。1.3研究方法与创新点介绍本论文采用的研究方法以及创新点。第2章相关理论介绍SpringBoot框架和智能垃圾分类的相关理论和技术。2.1SpringBoot框架概述阐述SpringBoot框架的基本概念、特点和优势。2.2垃圾分类技术介绍传统的垃圾分类方法和智能垃圾分类技术的原理及应用。2.3机器学习算法在垃圾分类中的应用讨论机器学习算法在智能垃圾分类系统中的关键作用。第3章SpringBoot智能垃圾分类系统设计详细介绍基于SpringBoot的智能垃圾分类系统的设计方案和实现过程。3.1系统架构设计给出系统的整体架构,包括前端、后端和数据库等组件。3.2智能分类模块设计阐述智能分类模块的具体设计,包括图像识别、传感器数据采集等功能。3.3系统安全性设计讨论系统在安全性方面的设计和实现,如用户认证、数据加密等。第4章系统实现与测试介绍SpringBoot智能垃圾分类系统的具体实现过程以及测试方法和结果。4.1系统实现详细阐述系统的实现过程,包括关键代码和技术难点。4.2系统测试方法与步骤给出系统测试的具体方法和步骤,包括单元测试、集成测试和系统测试等。4.3测试结果与分析对测试结果进行详细分析,验证系统的功能和性能是否达到预期目标。第5章结论与展望总结SpringBoot智能垃圾分类系统的研究成果,并展望未来的研究方向和应用前景。5.1研究结论概括本论文的主要研究结论和创新点,以及系统在实际应用中的表现。5.2展望分析当前研究的局限性,提出未来可能的研究方向和改进措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值