温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Redis有序集合如何使用

发布时间:2022-07-01 13:47:13 来源:亿速云 阅读:189 作者:iii 栏目:关系型数据库

这篇文章主要介绍“Redis有序集合如何使用”,在日常操作中,相信很多人在Redis有序集合如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis有序集合如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

Redis有序集合如何使用

Redis数据结构:有序集合

有序的集合。每个元素都由一个成员和一个与成员相关联的分值组成,成员以字符串存储,分值以64位双精度浮点数存储。成员不可重复,以分值大小进行排序,相同分值时以成员字典序排序。

数据结构

  • 字符串

  • 散列

  • 列表

  • 集合

  • 有序集合

  • HyperLogLog

  • 位图

  • 地理坐标

有序集合(sorted set)

  • 添加或更新成员
    1.zadd命令  格式:zadd key [NX|XX] [GT|LT] [CH] [INCR] score member [score member …]
    返回添加成功的新成员数量,若执行的是更新成员分值返回0。
    zadd key score member [score member ...]
    Redis有序集合如何使用
    XX选项的作用是只更新不添加,执行后返回0。
    zadd key XX score member [score member ...]
    Redis有序集合如何使用
    NX选项的作用是只添加不更新,执行成功返回添加元素的个数。
    zadd key NX score member [score member ...]
    Redis有序集合如何使用
    CH选项的作用是返回被修改成员的数量而非添加成功的成员数量,被修改包括新添加。
    zadd key CH score member [score member ...]
    Redis有序集合如何使用

  • 移除指定成员
    1.zrem命令  格式:zrem key member [member …]
    返回被移除成员的数量,成员不存在于集合中时自动忽略。
    zrem key member [member ...]
    Redis有序集合如何使用

  • 2.zremrangebyrank命令  格式:zremrangebyrank key start stop
    移除指定排名范围内的成员,返回被移除成员的数量,排名可使用正数排名或负数排名。
    zremrangebyrank key start stop
    Redis有序集合如何使用
    3.zremrangebyscore命令  格式:zremrangebyscore key min max
    移除指定分值范围内的成员,返回被移除成员的数量。min或max前加“(”表示取开区间即不包含边界值。
    zremrangebyscore key min max
    Redis有序集合如何使用
    4.zremrangebylex命令  格式:zremrangebylex key min max
    对于按照字典序排列的有序集合(即分值相同),移除指定字典序范围内的成员。返回被移除成员的数量,min、max的可取值包括:带“[”的值表示包含字典序边界,带“(”表示不包含字典序边界,“+”表示无穷大,“-”表示无穷小。
    zremrangebylex key min max
    Redis有序集合如何使用

  • 弹出元素
    1.zpopmax命令  格式:zpopmax key [count]
    弹出分值最高的count个成员,分值最高有多个元素时弹出字典序最大的成员,若未指定count默认1个,执行完成后返回被弹出元素的成员和分值。
    zpopmax key [count]
    Redis有序集合如何使用
    2.zpopmin命令  格式:zpopmin key [count]
    弹出分值最低的count个成员,分值最低有多个元素时弹出字典序最小的成员,若未指定count默认1个,执行完成后返回被弹出元素的成员和分值。
    zpopmin key [count]
    3.bzpopmax命令  格式:bzpopmax key [key …] timeout
    阻塞式的zpopmax命令,timeout为秒级精度。命令依次检查给定的有序集合,并从第一个非空集合弹出分值最大的元素,否则阻塞当前客户端直到有元素或超出超时时间返回nil。成功弹出元素时将返回一个列表,包含被弹出元素所在有序集合、成员以及分值。
    bzpopmax key [key ...] timeout
    Redis有序集合如何使用
    4.bzpopmin命令  格式:bzpopmin key [key …] timeout
    阻塞式的zpopmin命令,timeout为秒级精度。命令依次检查给定的有序集合,并从第一个非空集合弹出分值最小元素,否则阻塞当前客户端直到有元素或超出超时时间返回nil。成功弹出元素时将返回一个列表,包含被弹出元素所在有序集合、成员以及分值。
    bzpopmin key [key ...] timeout
    Redis有序集合如何使用
    客户端2:
    Redis有序集合如何使用

  • 获取成员分值
    1.zscore命令  格式:zscore key member
    获取给定成员的分值,集合不存在或者成员不存在时返回nil。
    zscore key member
    Redis有序集合如何使用

  • 对成员分值做运算
    1.zincrby命令  格式:zincrby key increment member
    执行完后返回当前成员分值,increment为正时自增,否则为自减;若键不存在或成员不存在则执行创建操作。
    zincrby key increment member
    Redis有序集合如何使用

  • 获取成员数量
    1.zcard命令  格式:zcard key
    返回集合包含的成员数量,集合不存在时返回0。
    zcard key
    Redis有序集合如何使用
    2.zcount命令  格式:zcount key min max
    获取指定分值范围内的成员数量,min或max前加“(”表示取开区间即不包含边界值,值+inf表示无穷大,-inf表示无穷小。
    zcount key min max
    Redis有序集合如何使用
    3.zlexcount命令  格式:zlexcount key min max
    对于按照字典序排列的有序集合(即分值相同),获取指定字典序范围内的成员数量,min、max的可取值包括:带“[”的值表示包含字典序边界,带“(”表示不包含字典序边界,“+”表示无穷大,“-”表示无穷小。
    zlexcount key min max
    Redis有序集合如何使用

  • 获取成员排名
    1.zrank命令  格式:zrank key member
    返回成员的升序排列排名,集合或成员不存在时返回nil。
    zrank key member
    Redis有序集合如何使用
    2.zrevrank命令  格式:zrevrank key member
    返回成员的降序排列排名,集合或成员不存在时返回nil。
    zrevrank key member
    Redis有序集合如何使用

  • 获取成员
    1.zrange命令  格式:zrange key min max [BYSCORE|BYLEX] [REV] [LIMIT offset count] [WITHSCORES]
    获取指定索引范围内的成员,按分值大小升序排列。WITHSCORES选项可在命令执行后返回分值,返回列表奇数位为成员,偶数位为对应分值。集合不存在时返回empty。
    zrange key min max [WITHSCORES]
    Redis有序集合如何使用
    2.zrevrange命令  格式:zrevrange key start stop [WITHSCORES]
    获取指定索引范围内的成员,按分值大小降序排列。WITHSCORES选项可在命令执行后返回分值,返回列表奇数位为成员,偶数位为对应分值。集合不存在时返回empty。
    zrevrange key start stop [WITHSCORES]
    Redis有序集合如何使用
    3.zrangebyscore命令  格式:zrangebyscore key min max [WITHSCORES] [LIMIT offset count]
    获取指定分值范围内的成员,按分值大小升序排列。WITHSCORES选项可在命令执行后返回分值,返回列表奇数位为成员,偶数位为对应分值。集合不存在时返回empty。
    zrangebyscore key min max [WITHSCORES] [LIMIT offset count]
    Redis有序集合如何使用
    [LIMIT offset count]选项的作用是限制返回的成员数量,offset指定需要跳过的成员数量,count执行最多返回成员的数量,count为负时取绝对值。
    Redis有序集合如何使用
    min或max前加“(”表示取开区间即不包含边界值,值+inf表示无穷大,-inf表示无穷小。
    Redis有序集合如何使用
    4.zrevrangebyscore命令  格式:zrevrangebyscore key max min [WITHSCORES] [LIMIT offset count]
    获取指定分值范围内的成员,按分值大小降序排列,注意max min顺序。
    zrevrangebyscore key max min [WITHSCORES] [LIMIT offset count]
    Redis有序集合如何使用
    5.zrangebylex命令  格式:zrangebylex key min max [LIMIT offset count]
    当成员分值相同时,获取指定字典序范围内成员,按字典序升序排列,min、max的可取值包括:带“[”的值表示包含字典序边界,带“(”表示不包含字典序边界,“+”表示无穷大,“-”表示无穷小。
    zrangebylex key min max [LIMIT offset count]
    Redis有序集合如何使用
    6.zrevrangebylex命令  格式:zrevrangebylex key max min [LIMIT offset count]
    当成员分值相同时,获取指定字典序范围内成员,按字典序降序排列,max、min的可取值包括:带“[”的值表示包含字典序边界,带“(”表示不包含字典序边界,“+”表示无穷大,“-”表示无穷小。
    zrevrangebylex key max min [LIMIT offset count]

  • 集合运算
    1.并集
     1)zunionstore命令  格式:zunionstore destination numkeys key [key …] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]
    numkeys为参与运算的集合数量,不对应时返回error,执行完后返回新集合的成员数量。并集得到的为成员集合,若参与运算的集合中有相同成员,则默认新集合的成员分值为原集合成员分数相加。
    zunionstore destination numkeys key [key ...]
    Redis有序集合如何使用
    AGGREGATE选项作用是指定使用的聚合函数,不指定时默认SUM。SUM指分值相加,MIN指取最小分值,MAX指取最大分值。
    zunionstore destination numkeys key [key ...] [AGGREGATE SUM|MIN|MAX]
    Redis有序集合如何使用
    WEIGHTS 选项作用是执行聚合前为每个集合分别设置一个权重,权重分别与集合中成员分值相乘得到新分值,然后执行聚合计算。
    Redis有序集合如何使用
     2)zunion命令  格式:zunion numkeys key [key …] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX] [WITHSCORES]
    执行完成后返回新集合成员。
    zunion numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX] [WITHSCORES]
    2.交集
     1)zinterstore命令  格式:zinterstore destination numkeys key [key …] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]
    执行完后返回新集合的成员数量。
    zinterstore destination numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]
     2)zinter命令  格式:zinter numkeys key [key …] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX] [WITHSCORES]
    执行完后返回新集合成员。
    zinter numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX] [WITHSCORES]
    注意
    1.集合运算可以使用集合作为输入,默认情况下,集合成员的分值看做1参与运算,可使用WEIGHTS选项设置权重改变集合分值。

  • 常见用法
    1.排行榜
    2.时间线

到此,关于“Redis有序集合如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI