Java使用Redis删除HashMap中的key踩到的坑

在Java中尝试通过HashMap的remove方法删除Redis中的key,再使用Hmset覆盖更新时发现无效。解决方案是直接使用Redis的HDEL命令删除指定HashMap中的Key。原因在于Redis仅会覆盖已存在的key,不感知Java端的remove操作。
摘要由CSDN通过智能技术生成

现象

Java使用Redis删除HashMap中的key时,取出对应的HashMap后通过Java中HashMap的remove方法移除key然后重新调用redis的Hmset方法将覆盖无效

示例代码

//通过key取出对应的HashMap
Map<String, String> ruleMap = jedisCluster.hgetAll("HashKey");
//通过java中移除HashMap中的Key
ruleMap.remove("ruleA");
//将移除后的HashMap重新存入redis的hashmap中
jedisCluster.hmset(key, ruleMap);
//问题来了,这里通过HashKey从redis中取出HashMap时发现ruleA的key的内容还在存在
Map<String, String> newRuleMap 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值