从redis 2.8.0版本起提供了SCAN系统命令用于扫描redis所有键
Redis的SCAN操作由于其整体的数据设计,无法提供特别准的scan操作,仅仅是一个“can ‘ t guarantee , just do my best”的实现,优缺点如下:
- 优点:
- 提供键空间的遍历操作,支持游标,复杂度O(1), 整体遍历一遍只需要O(N);
- 提供结果模式匹配;
- 支持一次返回的数据条数设置,但仅仅是个hints,有时候返回的会多;
- 弱状态,所有状态只需要客户端需要维护一个游标;
- 缺点:
- 无法提供完整的快照遍历,也就是中间如果有数据修改,可能有些涉及改动的数据遍历不到;
- 每次返回的数据条数不一定,极度依赖内部实现;
- 返回的数据可能有重复,应用层必须能够处理重入逻辑;
redis提供了灵活的数据查询方式,最牛的就是key的搜索支持正则表达式。
jedis.keys(“*”);表示搜索所有key
jedis.keys(“abc*”)表示搜索开头为abc的key数据
遍历了key就能遍历到value。
java代码
......
Set<String> s = jedis.keys("u_id_*");
Iterator<String> it = s.iterator();
while (it.hasNext()) {
String key = it.next();
String value = rd.jedis.get(key);
System.out.println(key +"---"+ value);
}
......
参考:
http://redis.io/commands/scan
http://www.w2bc.com/Article/3159
http://chenzhenianqing.cn/articles/1090.html
http://chenzhenianqing.cn/articles/1101.html