一、简介

  1. zset与set异同
  • 相同之处:

    都是没有重复元素的字符串集合
  • 不同之处:

    有序集合zset的每个成员都关联了一个评分(score),这个评分(score)被用来按照从最低分到最高分的方式排序集合中的成员。集合的成员是唯一的,但是评分可以是重复了 。

    因为元素是有序的, 所以你也可以很快的根据评分(score)或者次序(position)来获取一个范围的元素。

    访问有序集合的中间元素也是非常快的,因此你能够使用有序集合作为一个没有重复成员的智能列表。

二、常用命令

1、zadd 语法:zadd <key><score1><value1><score2><value2>…将一个或多个 member 元素及其 score 值加入到有序集 key 当中。
127.0.0.1:6379> zadd myzset 1 one			#在set集合基础上增加了score。
(integer) 1
127.0.0.1:6379> zadd myzset 2 two
(integer) 1
2、zrange 语法:zrange <key><start><stop> [withscores] 返回有序集 key 中,下标在<start><stop>之间的元素
127.0.0.1:6379> zrange myzset 0 -1				#获取myzset里的全部值
1) "one"
2) "two"
3) "three"
4) "four"
127.0.0.1:6379> zrange myzset 0 1 #获取myzset里下标在0-1的元素
1) "one"
2) "two"
127.0.0.1:6379> zrange myzset 0 3 #获取myzset里下标在0-3的元素
1) "one"
2) "two"
3) "three"
4) "four"
127.0.0.1:6379>
3、zrangebyscore 语法:zrangebyscore key minmax [withscores] [limit offset count] 返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列。
127.0.0.1:6379> zadd salary 1000 zhangsan			# 测试数据
(integer) 1
127.0.0.1:6379> zadd salary 2000 lisi
(integer) 1
127.0.0.1:6379> zadd salary 3000 wangwu
(integer) 1
127.0.0.1:6379> zrangebyscore salary -inf +inf # 显示整个有序集
1) "zhangsan"
2) "lisi"
3) "wangwu"
127.0.0.1:6379> zrangebyscore salary -inf +inf withscores # 显示整个有序集及成员的 score 值
1) "zhangsan"
2) "1000"
3) "lisi"
4) "2000"
5) "wangwu"
6) "3000"
127.0.0.1:6379> zrangebyscore salary -inf 2000 withscores # 显示工资 <=2000 的所有成员
1) "zhangsan"
2) "1000"
3) "lisi"
4) "2000"
127.0.0.1:6379> zrangebyscore salary (2000 5000 # 显示工资大于 2000 小于等于 5000 的成员
1) "wangwu"
127.0.0.1:6379>
4、zrevrangebyscore 语法:zrevrangebyscore key maxmin [withscores] [limit offset count]同上,改为从大到小排列。
127.0.0.1:6379> zadd salary 1000 zhangsan
(integer) 1
127.0.0.1:6379> zadd salary 2000 lisi
(integer) 1
127.0.0.1:6379> zadd salary 3000 wangwu
(integer) 1
127.0.0.1:6379> zrevrangebyscore salary +inf -inf # 逆序排列所有成员
1) "wangwu"
2) "lisi"
3) "zhangsan"
127.0.0.1:6379> zrevrangebyscore salary 5000 3000 # 逆序排列薪水介于 5000 和 2000 之间的成员
1) "wangwu"
127.0.0.1:6379>
5、zincrby 语法:incrby <key><increment><value> 为元素的score加上增量
127.0.0.1:6379> zadd myzset 1 why
(integer) 1
127.0.0.1:6379> zincrby myzset 12 why #分数加上增量12
"13"
127.0.0.1:6379> zrange myzset 0 -1 withscores
1) "why"
2) "13"
127.0.0.1:6379>
6、zrem 语法:zrem <key><value> 删除该集合下,指定值的元素。
127.0.0.1:6379> zrange test 0 -1 withscores				#测试数据
1) "www.baidu.com"
2) "1"
3) "www.cainiao.com"
4) "1"
5) "www.guge.com"
6) "1"
127.0.0.1:6379>
127.0.0.1:6379> zrem test www.cainiao.com #移除指定的值
(integer) 1
127.0.0.1:6379> zrange test 0 -1 withscores #查看test里面的数据
1) "www.baidu.com"
2) "1"
3) "www.guge.com"
4) "1"
127.0.0.1:6379> zrem test www.cainiao.com #移除不存在的值
(integer) 0
127.0.0.1:6379>
7、zcount `语法:zcount ·统计该集合,分数区间内的元素个数
127.0.0.1:6379> zadd myzset 1 hello				#添加测试数据
(integer) 1
127.0.0.1:6379> zadd myzset 1 why
(integer) 1
127.0.0.1:6379> zadd myzset 2 zhansgan
(integer) 1
127.0.0.1:6379> zadd myzset 3 lisi
(integer) 1
127.0.0.1:6379> zcount myzset 1 3 #统计数据为1-3的值
(integer) 4
127.0.0.1:6379>
8、zrank 语法:zrank <key><value> 返回有序集中指定成员的排名。其中有序集成员按分数值递增(从小到大)顺序排列。
127.0.0.1:6379> zrange salaory 0 -1 withscores			#测试数据
1) "zhangsan"
2) "2000"
3) "lisi"
4) "3000"
5) "wangwu"
6) "5000"
127.0.0.1:6379> zrank salaory lisi #获得李四的排名为第二,0为第一名
(integer) 1
127.0.0.1:6379> zrank salaory zhangsan
(integer) 0
127.0.0.1:6379> zrank salaory wangwu
(integer) 2
127.0.0.1:6379>

三、使用场景

  • 1、排行榜系统

    有序集合比较典型的使用场景就是排行榜系统。例如学生成绩的排名。某视频(博客等)网站的用户点赞、播放排名、电商系统中商品的销量排名等。
127.0.0.1:6379> zadd user:ranking 10 article1					#发表一篇文章,获得十个点赞
(integer) 1
127.0.0.1:6379> zincrby user:ranking -1 article1 #我觉得他写的不好,所以取消点赞
"9"
127.0.0.1:6379> zscore user:ranking article1 #查看文章的点赞数
"9"
127.0.0.1:6379> zrange user:ranking 0 9 #展示点赞最多的十篇文章
1) "article1"
127.0.0.1:6379>
  • 2、电话号码(姓名)排序
127.0.0.1:6379> zadd phone 0 13100111100 0 13110114300 0 13132110901
(integer) 3
127.0.0.1:6379> zadd phone 0 13200111100 0 13210414300 0 13252110901
(integer) 3
127.0.0.1:6379> zadd phone 0 13300111100 0 13310414300 0 13352110901
(integer) 3
127.0.0.1:6379> zrangebylex phone - + #获取所有号码
1) "13100111100"
2) "13110114300"
3) "13132110901"
4) "13200111100"
5) "13210414300"
6) "13252110901"
7) "13300111100"
8) "13310414300"
9) "13352110901"
127.0.0.1:6379> zrangebylex phone [132 (133 #获取132号段
1) "13200111100"
2) "13210414300"
3) "13252110901"
127.0.0.1:6379> zrangebylex phone [132 (134 #获取132,133号段
1) "13200111100"
2) "13210414300"
3) "13252110901"
4) "13300111100"
5) "13310414300"
6) "13352110901"
127.0.0.1:6379>

更多关于zset命令查看官网

9、Redis五大数据类型---有序集合Zset(sorted set)的更多相关文章

  1. redis:php-redis中有序集合 zset的使用

    ZSET(stored set) 和 set 一样是字符串的集合,不同的是每个元素都会关联一个 double 类型的 score .实现使用的是 skip list 和 hash table , sk ...

  2. redis 有序集合(zset)函数

    redis 有序集合(zset)函数 zAdd 命令/方法/函数 Adds the specified member with a given score to the sorted set stor ...

  3. Redis对象——有序集合(ZSet)

    有序集合类型 (Sorted Set或ZSet) 相比于集合类型多了一个排序属性 score(分值),对于有序集合 ZSet 来说,每个存储元素相当于有两个值组成的,一个是有序结合的元素值,一个是排序 ...

  4. php使用redis的有序集合zset实现延迟队列

    延迟队列就是个带延迟功能的消息队列,相对于普通队列,它可以在指定时间消费掉消息. 延迟队列的应用场景: 1.新用户注册,10分钟后发送邮件或站内信. 2.用户下单后,30分钟未支付,订单自动作废. 我 ...

  5. 【Redis】命令学习笔记——列表(list)+集合(set)+有序集合(sorted set)(17+15+20个超全字典版)

    本篇基于redis 4.0.11版本,学习列表(list)和集合(set)和有序集合(sorted set)相关命令. 列表按照插入顺序排序,可重复,可以添加一个元素到列表的头部(左边)或者尾部(右边 ...

  6. 聊聊Mysql索引和redis跳表 ---redis的有序集合zset数据结构底层采用了跳表原理 时间复杂度O(logn)(阿里)

    redis使用跳表不用B+数的原因是:redis是内存数据库,而B+树纯粹是为了mysql这种IO数据库准备的.B+树的每个节点的数量都是一个mysql分区页的大小(阿里面试) 还有个几个姊妹篇:介绍 ...

  7. Redis五大数据类型的常用操作

    在上一篇博文<centos安装redis>中,已经详细介绍了如何在centos上安装redis,今天主要介绍下Redis五大数据类型及其五大数据类型的相关操作. Redis支持五种数据类型 ...

  8. Redis五大数据类型

    首先说明下,Redis是:单线程+多路IO复用技术!!! string set  >  key  +  zset          list hash 常用的几个命令: >keys * 查 ...

  9. 细谈Redis五大数据类型

    文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. 上一篇文章有提到,Redis中使用最频繁的有5种数据类型:String.List.Hash.Set.SortS ...

随机推荐

  1. [loj3075]组合数求和

    Subtask1:​​​$m,nd\le 2\times 10^{3}$ 对$M$质因数分解,假设$M=\prod_{i=1}^{k}p_{i}^{\alpha_{i}}$(其中$p_{i}$为素数) ...

  2. [bzoj1081]超级格雷码

    手动模拟一组样例,可以理解大致应该如何操作具体实现中,记录每一位当前应该+1还是-1,然后操作最低的位并将后面的+1和-1全部取反即可 1 #include<bits/stdc++.h> ...

  3. [loj3278]收获

    人的移动之间会相互影响,因此不妨看成果树逆时针移动,显然果树之间独立 考虑建图:1.每一棵果树向其逆时针旋转后第一个人连边:2.每一个人向其逆时针旋转不小于$C$的第一个人连边(即下一个摘的人),边权 ...

  4. [bzoj2257]瓶子和燃料

    先考虑选出k个后答案最小会是多少,容易发现其实就是所有的gcd(就是$ax+by=gcd(a,b)$的推广)然后相当于要最大化gcd,反过来可以将所有数的约数都打上+1标记,+1标记不少于k个且最大的 ...

  5. 花了30天才肝出来,史上最全面Java设计模式总结,看完再也不会忘

    本文所有内容均节选自<设计模式就该这样学> 序言 Design Patterns: Elements of Reusable Object-Oriented Software(以下简称&l ...

  6. 从头带你撸一个Springboot Starter

    我们知道 SpringBoot 提供了很多的 Starter 用于引用各种封装好的功能: 名称 功能 spring-boot-starter-web 支持 Web 开发,包括 Tomcat 和 spr ...

  7. centos与ubuntu安装及相关问题解答

    1.按系列罗列Linux的发行版,并描述不同发行版之间的联系与区别. 答:Linus的发行版本有slackware,debian,redhat,Alpine,ArchLinux,Gentoo,LFS, ...

  8. C/C++ Qt TableDelegate 自定义代理组件

    TableDelegate 自定义代理组件的主要作用是对原有表格进行调整,例如默认情况下Table中的缺省代理就是一个编辑框,我们只能够在编辑框内输入数据,而有时我们想选择数据而不是输入,此时就需要重 ...

  9. [NOIP2017 提高组] 列队

    考虑我们需要维护的是这样一个东西. 即可能变化的只有每一行前\(m - 1\)个,和最后一列. 我们考虑对每一行开一个权值线段树,记录原本序列的第\(x\)个是否被一出,且用一个\(vector\)记 ...

  10. Codeforces 286E - Ladies' Shop(FFT)

    Codeforces 题面传送门 & 洛谷题面传送门 好久没刷过 FFT/NTT 的题了,写篇题解罢( 首先考虑什么样的集合 \(T\) 符合条件.我们考察一个 \(x\in S\),根据题意 ...