Spring 缓存 Cache容易忽略的问题

本文深入解析Spring Cache的工作原理,强调其与AOP的关系,以及在实际应用中如何避免缓存失效的问题。阐述了value和key参数的重要性,以及如何正确设置以确保业务逻辑与缓存一致。

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

1.Spring 的Cache是同理与AOP代理的,不可以在同一个类中相互调用,否则会缓存失效直接查询。

2.Spring 的Cache有两个最主要的参数,value与key, value代表缓存的名称,key为缓存中存储键值对的key,这里尤其需要注意value的名称是可以在多个方法上使用想用名称的,但是如果没有在缓存方法的key中明确指明方法是从该缓存中获取值,则可能会出现始终读取缓存而缓存中没有该值,但又并不触发调用业务查询方法的情况(具体原因可能是在别的缓存中存在相同key的情况)。根据业务规则可以增加 #root.caches 指定查询缓存为当前缓存。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值