借用@Caching实现
入参是基本类型的:
1
2
3
4
5
6
|
@Caching (evict={ @CacheEvict (value = Cache.CONSTANT, key = "'" + CacheKey.SINGLE_ROLE_NAME + "'+#roleId" ), @CacheEvict (value = Cache.CONSTANT, key = "'" + CacheKey.ROLES_NAME + "'+#roleId" ), @CacheEvict (value = Cache.CONSTANT, key = "'" + CacheKey.SINGLE_ROLE_NAME + "'+#roleId" )}) public ResponseData remove( @RequestParam Long roleId) { ……………… } |
入参是对象的:
1
2
3
4
5
6
7
|
@Caching (evict={ @CacheEvict (value = Cache.CONSTANT, key = "'" + CacheKey.SINGLE_ROLE_NAME + "'+#roleDto.roleId" ), @CacheEvict (value = Cache.CONSTANT, key = "'" + CacheKey.ROLES_NAME + "'+#roleDto.roleId" ), @CacheEvict (value = Cache.CONSTANT, key = "'" + CacheKey.SINGLE_ROLE_NAME + "'+#roleDto.roleId" )}) public ResponseData edit(RoleDto roleDto) { this .roleService.editRole(roleDto); return SUCCESS_TIP; } |
补充:@CacheEvict 模糊删除缓存问题-RedisTemplate 模糊key删除缓存
缓存管理使用注解形式,非常方便了我们的使用,然而今天我想 使用 @CacheEvict 的实和key 进行 模糊删除,发现 @CacheEvict 貌似不支持这样的操作,然后想起 RedisTemplate 好像支持 key的模糊匹配。
于是,方法有了
既然@CacheEvict做不到,那就用 RedisTemplate
第一步:
获取key
这里的key就是 : user:role* 这样的
1
|
Set<Object,Object> keys = redisTemplate.keys( key ); |
第二步:
判断 keys 非空,然后进行删除
1
2
3
|
if (CollectionUtils.isNotEmpty(keys)) { redisTemplate.delete(keys); } |
总结:
删除缓存的时候,如果 keys 是空的,则没有反应,因为查看源码可知,redisTemplate 帮你判断了,如果是 空的则 return
此处也有可能删不掉,删不掉很可能就是 key 的序列化问题
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/Amy126/article/details/88661773