如何使用@CachePut更新数据库和更新缓存
发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,小编给大家分享一下如何使用@CachePut更新数据库和更新缓存,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!关于更新缓存
千家信息网最后更新 2025年02月02日如何使用@CachePut更新数据库和更新缓存
小编给大家分享一下如何使用@CachePut更新数据库和更新缓存,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
关于更新缓存 ,要注意两点
1、@Cacheable的key
要和@CachePut 的key一致
比如:
@Cacheable(key = "'userCache'") //缓存, public Uuser findByEmail(String email) { System.err.println("执行这里,说明缓存中读取不到数据,直接读取数据库...."); return redisMapper.findByEmail(email); } @CachePut(key = "'userCache'") //userCache要加''单引号,表示这是一个字符串 public Uuser updateSelf(String nickname, String email) { System.err.println("执行这里,更新数据库,更新缓存...."); uuserMapper.updateSelf(nickname, email); Uuser uuser = redisMapper.findByEmail(email); return uuser; }
2、@CachePut的返回值
要和@Cacheable的返回值一样
如果@Cacheable 返回的是一个对象,@CachePut 返回也要是对象,否则会报类型转换异常,如上代码 返回的都是 Uuser.
缓存的CachePut冲突Cacheable
CachePut 跟 Cacheable放在一起, Cacheable的效果就跟 CachePut 一样的,每次都会去查数据库,虽然有缓存。
/** * * @param id * @return */@Caching( put = { @CachePut(key = "T(cn.a.b.constant.RedisKey).OPEN_MEDIUM_INFO + #result.mediumBankCard", unless="#result.mediumBankCard==null or #result.status !='2'"), @CachePut(key = "T(a.b.c.constant.RedisKey).ACCOUNT_CODE + #result.accountCode", unless="!{'0','1','2','3'}.contains(#result.mediumStatus)"), @CachePut(key = "T(a.b.c.constant.RedisKey).CERT_NO+ #result.certNo", unless="#result.certNo==null or !{'0','1','2','3'}.contains(#result.status)")}, cacheable = {@Cacheable(key="T(a.b.c.constant.RedisKey).ID + #id")})public XXXInfo selectByPrimaryKey(Long id){ return mapper.selectByPrimaryKey(id);}
可以分解成两个
Service.java/** * * @param id * @return */@Caching( put = { @CachePut(key = "T(cn.a.b.constant.RedisKey).OPEN_MEDIUM_INFO + #result.mediumBankCard", unless="#result.mediumBankCard==null or #result.status !='2'"), @CachePut(key = "T(a.b.c.constant.RedisKey).ACCOUNT_CODE + #result.accountCode", unless="!{'0','1','2','3'}.contains(#result.mediumStatus)"), @CachePut(key = "T(a.b.c.constant.RedisKey).CERT_NO+ #result.certNo", unless="#result.certNo==null or !{'0','1','2','3'}.contains(#result.status)")})public XXXInfo selectByPrimaryKey(Long id){ return mapper.selectByPrimaryKey(id);} Mapper.java{ @Cacheable(key="T(a.b.c.constant.RedisKey).ID + #p0") XXXXInfo selectByPrimaryKey(Long id);}
mybatis 接口类参数。用#参数名无效。 只能用#p0, #p1
以上是"如何使用@CachePut更新数据库和更新缓存"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
缓存
更新
数据
数据库
篇文章
内容
参数
对象
一致
不怎么
两个
代码
大部分
如上
字符
字符串
引号
接口
效果
更多
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
沪动网络技术有限公司怎么样
缺少网络安全意识英语作文
网络安全与可信计算
数据库image怎么用
易佰软件开发
重启受管理的服务器
mac使用ssh访问服务器
运营培训哪里可以学习网络技术
数据库 查询 实验总结
web项目数据库乱码问题
服务器电源尺寸规格型号
blob是什么数据库的类型
警惕网络安全事件
软件开发哪些条款
计算机四级网络技术题型
爱思唯尔属于全文数据库吗
软件开发技术协作
珠海家政软件开发收费
如何设置默认数据库文件夹里
山东工业软件开发靠谱吗
新闻系统软件开发费用
金华公安网络安全
软件开发和程序哪个重要
第三方软件开发费用
软件开发与销售好做吗
外企软件开发j5是什么级别
网络安全360天擎
测试程序及数据库安全问题
安全风险管控系统服务器地址
网络安全隐私保护法律法规