redis索引怎么实现的
今天小编给大家分享的是redis索引怎么实现的,相信很多人都不太了解,为了让大家更加了解redis索引,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。
创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站建设、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的丽水网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
redis并不直接支持索引,需要通过自己来维护。
对于非范围唯一索引,我们可以简单的把索引也存成KV对,v保存主key即可,而范围检索,或者非唯一索引,则要使用redis 的 zset来实现。
举例一个传统的用户系统例子
uid 用户id name 用户名 credit 用户积分 type 类型
可以直接放到一个hashset中
hmset usr:1 uid 1 name aaa credit 10 type 0 hmset usr:2 uid 2 name bbb credit 20 type 1
通过uid检索很快,但是如果要查询type=1的用户,则只能全扫描!
在关系数据库中,我们可以简单在type上建立索引
select * from usr where type=1
这样的SQL就可以高效执行了。redis中需要我们自己再维护一个zset
zadd usr.index.type 0 0:1 zadd usr.index.type 0 1:2
注意,所有权重都设置成0,这样可以直接按值检索,然后可以通过
zrangebylex usr.index.type [1: (1;
关于redis索引怎么实现的就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。
本文题目:redis索引怎么实现的
标题网址:http://pwwzsj.com/article/gjdcde.html