Sort Set 排序集合类型:
- sorted set 排序集合,也就是有序集合
- 和集合一样也是string类型元素的集合,且不允许重复的成员。
- 不同的是每个元素都会关联一个权。
- 通过权值可以有序的获取集合中的元素。
该Sort set 类型适合场合:
获得热门帖子(回复量)信息:
select * from message order by backnum desc limit 5;
通过sql语句可以实现,但是sql语句比较耗费mysql数据库资源。
我们来用sorted set 实现获取最热门的前5帖子信息:
排序集合中的每个元素都是值、权的组合
(之前的set集合类型每个元素就只是一个 值)
如上图:11是值,102是权
这里跟上一篇的方法类似,我们做一个sort sed排序集合,只保留回复量最高的前5个帖子。每个帖子被回复的时候,都有机会进入该集合里面。
Sort Set 排序集合操作:
启动redis
选择数据库:
下面我们来看一下sorted set 排序类型的操作:
创建一个排序集合 hotmessage ,在里面添加5个元素:
(如下图.102是权,11是值)
我们继续添加一个元素,然后排序:
zrevrange key start end :返回一个有序集合。按权从高到低排序。
下面我们删除最低的值为14的:
zremrangebyrank key min max :删除集合中排名给定区间的元素。(权值由小到大排序)
我们把剩下的值也操作一下:
可以直接进行添加删除操作:
zrank key member:
返回指定元素在集合中的排名(下标),集合中元素按权由小到大排序。
上图可见,共5个元素,13最小,16第二,
所以16的下标为1,18下标为4.
zrevrank key member:
返回指定元素在集合中的排名(下标)
跟上面的zrank操作相同。不过集合中元素按权由大到小排序。
zcard key:
计算集合中有多少个元素
zincrby key incr member:
按照incr的幅度,增加对应member的score值,返回score值。
member是值,score是权,在这里权就是值对应的回复量
基本操作就介绍到这里。
ps关于重复元素:
set类型:没有
list链表类型: 有
sort set: 没有