Sorted-Set和Set类型极为相似,他们都是字符串的集合,都不允许重复的成员出现在一个Set中。他们之间的主要差别是Sorted-Set中的每一个成员都会有一个分数(score)与之关联,Redis正是通过分数来为集合中的成员进行从小到大的排序。然而需要额外指出的是,尽管Sorted-Set中的成员必须是唯一的,但是分数(score)确实可以重复的。
在Sorted-Set中添加、删除或者更新一个成员都是非常快速的操作,其时间复杂度为集合中成员数量的对数。由于Sorted-Set中的成员在集合中的位置是有序的。因此,即便是访问位于集合中部的成员也仍然是非常高效的。事实上,Redis所具有的这一特征在很多其它类型的数据库中是很难实现的,换句话说,在该点上要达到和Redis同样的高效,在其它数据库中进行建模是非常困难的。例如:游戏排名、微博热点话题等使用场景。
常用命令添加元素
zadd key score member score2 member2 …: 将所有成员以及该成员的分数存放到sorted-set中。如果该元素已经存在则会用新的分数替换原有的分数。返回值是新加入到集合中的元素个数,不包含之前已经存在的元素。
获得元素
zscore key member: 返回指定成员的分数
zcard key: 获取集合中的成员数量
删除元素
zrem key member[member …] : 移除集合中指定的成员,可以指定多个成员。
范围查询
**zrange key start end[withscores] : ** 获取集合中脚标为start-end的成员,[withscores]参数表明返回的成员包含其分数。
等等。。。。。。
使用场景1、可以用于一个大型在线游戏的积分排行榜。每当玩家的分数发生变化时,可以执行ZADD命令跟新玩家的分数,此后再通过ZRANGE命令获取积分TOPTEN的用户信息。当然我们也可以利用ZRANK命令通过username来获取玩家的排行信息。最后我们将组合使用ZRANGE和ZRANK命令快速的获取和某个玩家积分相近的其它用户信息。
2、Sorted-Set 类型还可用于构建索引数据。