Redis 模糊key查询

瑞星  金牌会员 | 2024-6-15 01:30:48 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 802|帖子 802|积分 2406

Redis 提供了两种紧张的方式来执行模糊查询Key的操作:
方法1:KEYS 下令

  1. 1KEYS pattern
复制代码
KEYS 下令答应你按照给定的模式来查找数据库中的所有匹配项。例如:
  1. 1redis> KEYS user*
复制代码
这条下令会返回所有以 "user" 开头的key。
然而,请注意,在生产环境中并不保举使用 KEYS 下令进行模糊查询,因为当数据库包含大量键时,该下令会阻塞整个Redis服务器直到下令完成,影响其他客户端请求,而且对于大数据集非常低效。
方法2:SCAN 下令

  1. 1SCAN cursor [MATCH pattern] [COUNT count]
复制代码
SCAN 下令是Redis从2.8版本开始引入的一个更安全的选择,它可以逐步迭代数据库中的key空间,不会阻塞服务器,而且可以担当可选的MATCH参数来实现模糊匹配。例如:
  1. 1redis> SCAN 0 MATCH user*
复制代码
这里,SCAN 下令配合 MATCH 参数同样可以找到所有以 "user" 开头的key,但它不是一次性返回所有结果,而是返回一个游标和一批匹配的结果。你需要多次调用 SCAN 来遍历所有可能的匹配项。
建议在处理大量数据时始终优先思量使用 SCAN 下令替代 KEYS,以制止潜在的性能问题和对服务器的影响。
Springboot 整合redis客户端可以如许使用
  1.      @Autowired
  2.      private StringRedisTemplate stringRedisTemplate;
  3. /**
  4.      * 查找匹配的key
  5.      *
  6.      * @param pattern
  7.      * @return
  8.      */
  9.     public List<String> scanKeysByPattern(String pattern) {
  10.         // 获取Redis连接
  11.         RedisConnection connection = stringRedisTemplate.getConnectionFactory().getConnection();
  12.         try {
  13.             ScanOptions options = ScanOptions.scanOptions().match(pattern).build();
  14.             Cursor<byte[]> cursor = connection.scan(options);
  15.             List<String> matchedKeys = new ArrayList<>();
  16.             while (cursor.hasNext()) {
  17.                 byte[] keyBytes = cursor.next();
  18.                 // 反序列化为字符串
  19.                 String key = new String(keyBytes, StandardCharsets.UTF_8);
  20.                 matchedKeys.add(key);
  21.             }
  22.             return matchedKeys;
  23.         }finally {
  24.             connection.close();
  25.         }
  26.     }
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

瑞星

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表