遍历读取整个redis数据库实例

从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

你可能感兴趣的:(遍历读取整个redis数据库实例)