首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Hibernate + Ehcache更新不会直接刷新缓存

Hibernate是一个Java持久化框架,它提供了对象关系映射(ORM)的功能,可以将Java对象映射到关系型数据库中的表。而Ehcache是一个开源的Java缓存框架,它提供了内存缓存的功能,可以提高系统的性能和响应速度。

当使用Hibernate和Ehcache一起进行开发时,可以通过配置来实现缓存的管理和更新。在默认情况下,Hibernate会自动将查询结果缓存到Ehcache中,并在下次查询相同数据时直接从缓存中获取,从而提高查询的效率。

然而,当使用Hibernate进行数据更新操作时,例如插入、更新或删除数据,Hibernate并不会直接刷新缓存。这是因为Hibernate采用了缓存失效策略,即在数据更新后,会将缓存中对应的数据标记为失效,而不是立即刷新缓存。这样做的目的是为了避免频繁的缓存刷新操作,提高系统的性能。

当下次查询需要使用到被标记为失效的数据时,Hibernate会重新从数据库中加载最新的数据,并更新缓存。这个过程是自动完成的,开发人员无需手动干预。

然而,有时候我们需要在数据更新后立即刷新缓存,以保证数据的一致性。这时可以通过手动调用Ehcache的API来实现缓存的刷新。具体的做法是,在数据更新操作完成后,调用Ehcache的remove方法或evictAll方法来清除缓存中对应的数据,下次查询时会重新加载最新的数据并更新缓存。

总结起来,Hibernate + Ehcache更新不会直接刷新缓存,而是采用缓存失效策略。如果需要在数据更新后立即刷新缓存,可以通过手动调用Ehcache的API来实现。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Hibernate缓存配置

    一级缓存 Hibernate的一级缓存是由Session提供的,因此它只存在于Session的生命周期中,当程序调用save(),update(),saveorupdate()等方法 及调用查询接口list,filter,iterate时,如session缓存中还不存在相应的对象,Hibernate会把该对象加入到一级缓存中, 当Session关闭的时候该Session所管理的一级缓存也会立即被清除 Hibernate的一级缓存是Session所内置的,不能被卸载,也不能进行任何配置 二级缓存配置: 1、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置: <property name="hibernate.cache.use_second_level_cache">true</property> 2、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个 缓存工具。如下配置指定Hibernate使用EhCache缓存工具。 <property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property> 3、Hibernate在默认情况下并不会对所有实体对象进行缓,所以,我们需要指定缓存哪些对象, 在实体对象的映射文件中(相应的<class>标签内部),添加如下配置: <cache usage="read-only"/> usage="read-only"是“只读”缓存策略。 注意,这个<cache>标签只能放在<class>标签的内部,而且必须处在<id>标签的前面!!! 这个<cache>标签放在哪些<class>标签下面,就说明会多这些类的对象进行缓存 4、对于第3步,有一个可选的方案是在hibernate.cfg.xml文件中指定哪些类的对象需要缓存, 而不需要使用<cache>标签来指定。如: 在hibernate.cfg.xml中添加如下配置: <class-cache class="com.bjsxt.hibernate.Classes" usage="read-only" /> 注意,这个<class-cache>标签必须放在<mapping>标签的后面!! Hibernate缓存配置 _____________________________________________________________________________________ Hibernate的缓存分为:   一级缓存:在Session级别的,在Session关闭的时候,一级缓存就失效了。   二级缓存:在SessionFactory级别的,它可以使用不同的缓存实现,如EhCache、JBossCache、OsCache等。 缓存的注释写法如下,加在Entity的java类上:   @Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) 缓存的方式有四种,分别为:   CacheConcurrencyStrategy.NONE   CacheConcurrencyStrategy.READ_ONLY,只读模式,在此模式下,如果对数据进行更新操作,会有异常;   CacheConcurrencyStrategy.READ_WRITE,读写模式在更新缓存的时候会把缓存里面的数据换成一个锁,其它事务如果去取相应的缓存数据,发现被锁了,直接就去数据库查询;   CacheConcurrencyStrategy.NONSTRICT_READ_WRITE,不严格的读写模式则不会的缓存数据加锁;   CacheConcurrencyStrategy.TRANSACTIONAL,事务模式指缓存支持事务,当事务回滚时,缓存也能回滚,只支持JTA环境。 另外还有如下注意事项:   1、查询缓存需要在Query的相应方法执行前加上这么一句:   query.setCacheable(true);   在使用Hibernate时,获得的query有setCacheable方法,可以设置使用缓存,但当使用JPA时,javax.persistence.Query并没有setCacheable方法,此时如果JPA的实现是Hibernate时,可以将其进行如下转化,再调用setCacheable方法(如果JPA的实现是其它ORMAP框架,就不知道怎么做了)。 if (query

    01

    Hibernate二级缓存配置

    Cache就是缓存,它往往是提高系统性能的最重要手段,对数据起到一个蓄水池和缓冲的作用。Cache对于大量依赖数据读取操作的系统而言尤其重要。在大并发量的情况下,如果每次程序都需要向数据库直接做查询操作,它们所带来的性能开销是显而易见的,频繁的网络舆,数据库磁盘的读写操作都会大大降低系统的性能。此时如果能让数据库在本地内存中保留一个镜像,下次访问的时候只需要从内存中直接获取,那么显然可以带来不小的性能提升。引入Cache机制的难点是如何保证内存中数据的有效性,否则脏数据的出现将会给系统带来难以预知的严重后果。虽然一个设计得很好的应用程序不用Cache也可以表现出让人接受的性能,但毫无疑问,一些对读取操作要求比较高的应用程序可以通过Cache获得更高的性能。对于应用程序,Cache通过内存或磁盘保存了数据库中的当前有关数据状态,它是一个存储在本地的数据备份。Cache位于数据库和应用程序之间,从数据库更新数据,并给程序提供数据。

    02

    一级缓存、二级缓存、查询缓存

    1):Session 级别的缓存,与session邦定。它的生命周期和session相同。 Session消毁,它也同时消毁;管理一级缓存,一级缓存无法取消 2):两个Session 不能共享一级缓存,因它会伴随session的生命周期的创建和消毁; 3):get使用了一级缓存,用get查数据时,首先检查缓存中是否有该数据,如果有直接从缓存中取数据,如果没有再查询数据库,并且将数据放入缓存中。 load也支持一级缓存。load还支持lazy.当load从数据库中查询数据后,也会将数据放入缓存。 unique/list查询不会去查看缓存,但是list查询的实体对象将会放入缓存中。 4):与一级缓存相关方法: session.clear():清除一级缓存中所有的对象。 boolean contains(Object entity):判断一级缓存中是否有给定的对象。 session.evict(Object entity):从一级缓存中清除指定的对象。 session.flush():把一级缓存中的脏数据同步到数据库中。 session.refresh((Objectentity):强制重新查询对象,相当于把数据库中的数据同步到一级缓存中。

    03
    领券