这篇文章主要讲解了“spring redis怎么实现模糊查找key”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“spring redis怎么实现模糊查找key”吧!
Set<String> keySet = stringRedisTemplate.keys("keyprefix:"+"*");
需要使用StringRedisTemplate,或自定义keySerializer为StringRedisSerializer的redisTemplate
redis里模糊查询key允许使用的通配符:
* 任意多个字符
? 单个字符
[] 括号内的某1个字符
org.springframework.data.redis.core.RedisTemplate public Set<K> keys(K pattern) { byte[] rawKey = rawKey(pattern); Set<byte[]> rawKeys = execute(connection -> connection.keys(rawKey), true); return keySerializer != null ? SerializationUtils.deserialize(rawKeys, keySerializer) : (Set<K>) rawKeys; }
Redis2.8以后可以使用scan获取key
基于游标迭代分次遍历key,不会一次性扫描所有key导致性能消耗过大,减少服务器阻塞
可以通过count参数设置扫描的范围
Set<String> keys = new LinkedHashSet<>(); stringRedisTemplate.execute((RedisConnection connection) -> { try (Cursor<byte[]> cursor = connection.scan( ScanOptions.scanOptions() .count(Long.MAX_VALUE) .match(pattern) .build() )) { cursor.forEachRemaining(item -> { keys.add(RedisSerializer.string().deserialize(item)); }); return null; } catch (Exception e) { throw new RuntimeException(e); } });
Reids SCAN命令官方文档
String key = "noteUserListenedPoi:*"; redisTemplate.delete(key); LOGGER.info("redis中用户收听历史被清空");
后来测试发现模糊查询是可以用的, 删除改成
Set<String> keys = redisTemplate.keys("noteUserListenedPoi:" + "*"); redisTemplate.delete(keys); LOGGER.info("{}, redis中用户收听历史被清空"
感谢各位的阅读,以上就是“spring redis怎么实现模糊查找key”的内容了,经过本文的学习后,相信大家对spring redis怎么实现模糊查找key这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。