6 有序集合ZSet(Sorted Set)

  • ZSet和Set的区别:

          ZSet中的每一个成员都会有一个分数与之关联,redis正是利用这个分数对成员进行由小到大的排序,尽管ZSet中的成员必须是唯一的,但是分数是可以重复的,所以在ZSet中添加、删除和            更新一个成员都是十分快速的。时间复杂度为集合中成员的个数的对数。由于ZSet中的成员在集合中的位置是有序的,因此即使是访问集合中部的成员也是非常高效的。

  • ZSet中的成员在集合中的位置是有序的

常用命令:

  • 添加元素
  • 删除元素
  • 获得元素
  • 范围查询
  • 扩展命令
复制代码
>zadd mysort 70 xiao 80 lin 90 zi  //添加元素
(integer) 3
>zadd mysort 100 xiao   //添加已经存在的元素会添加不成功
(integer) 0

>zscore mysort xiao //获取元素分数
"100"

>zcard mysort //获取成员数量
(integer) 3

>zrem mysort zi xiao //删除元素
(integer) 2

>zadd mysort 85 hello 95 world
(integer) 2
>zrange mysort 0 -1 //范围查询
1) “hello”
2) “lin”
3) “world”

>zrange mysort 0 -1 withscores //带有分数的范围查询
1) “hello” 
2) “853) “lin”
4) “905) “world”
6) “95>zrevrange mysort 0 -1 withscores //从大到小范围查询
1) “world”
2) “953) “lin”
4) “905) “hello” 
6) “85> zrangebyscore mysort  0 90 withscores //获取分数范围内的值
1) “hello” 
2) “853) “lin”
4) “90
复制代码

ZSet使用场景:

  • 大型在线游戏积分排行榜
  • 构建索引数据
posted @   小林子奋斗的点滴  阅读(1867)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示