不得不说,最近在使用redis的incr的功能的时候,着实是踩了不少的坑啊!
前面我写的一篇文章里面,我提到通过incr产生的键在用普通的get的方式去获取的时候,是获取不到的,所以我不得不通过特殊的代码指定key来获取,而这个操作在我的心里面其实埋上了一颗疑问的种子,就是删除的时候会不会也存在问题。所以机智的我产生了部分数据,并调取删除方法尝试删除,果不其然,删除失败了。真的是不知道是这个Spring boot引用的代码内部实现的问题还是怎么样?但是主要我们还是要将视角聚焦在怎么先解决这个问题,所以我看了下他那个关于incr方面的RedisAtomicLong的内部实现,结果呵呵~它内部并没有删除的代码,但是只有设置和获取相关数据的代码,而当中过期时间的设置最终让我警觉起来,所以我最终实现了一个代码:
1 public void removeAtomicLong(String key) { 2 RedisAtomicLong entityIdCounter = new RedisAtomicLong(key, redisTemplate.getConnectionFactory()); 3 entityIdCounter.expire(0, TimeUnit.MILLISECONDS); 4 }
结果功能实现~~!