前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C# CsRedis的初探(六)-- Redis常用命令整理(有序集合类型)

C# CsRedis的初探(六)-- Redis常用命令整理(有序集合类型)

作者头像
Vaccae
发布2019-07-24 13:19:15
1.3K0
发布2019-07-24 13:19:15
举报
文章被收录于专栏:微卡智享

Redis常用命令整理有序集合类型

增加元素

zadd key score member [ score member ...... ]

zadd 命令用来向有序集合中加入一个元素和该元素的分数,如果该元素已经存在,则会用新的分数替换原有的分数。zadd命令的返回值是新加入到集合中的元素个数(不包含之前已经存在的元素)


获得元素的分数

zscore key member

返回为member 成员的 score 值,以字符串形式表示。


获得排名在某个范围的元素列表

zrange key start stop [ withscores ]

zrange 命令会按照元素分数从小到大的顺序返回索引从 start 到 stop 之间的所有元素(包含两端的元素)。zrange 命令和 lrange 命令十分相似,如索引都是从0开始,负数代表从后向前查找(-1 表示最后一个元素)。如果需要同时获得元素的分数的话,可以在zrange 命令的尾部加上 widthscores 参数

注:如果两个元素的分数相同,redis会按照字典顺序(即 0<9<A<Z<a<z 这样的顺序)来进行排列。如果元素的值是中文,则取决于中文的编码方式

zrevrange key start stop [ withscores ]

zrevrange 命令和 zrange 的唯一不同在于 zrevrange 是按照元素分数从大到小的顺序给定结果的


获得指定分数范围内的元素

zrangebyscore key min max [ withscores ] [ limit offset count ]

该命令按照元素分数从小到大的顺序返回分数在 min 到 max 之间(包含 min 和max 的元素)

如果希望分数范围不包含端点值,可以在分数前加上 "(" 符号,例如:希望返回80分到100分的的数据,可以包含80分单不包含100分

命令:zrangebyscore scoreboard 80 (100 widthscores

min 和 max 还支持无穷大,同 zadd 命令一样,-inf 和 +inf 分别表示负无穷大和正无穷大。比如希望得到所有分数高于 80分(不包含80分)的人的名单,但是却不知道最高分是多少,这是就可以使用 +inf zrangebyscore scoreboard (80 +inf

命令 limit offset count 与 SQL 中的用法基本相同,即在获得的元素列表的基础上向后偏移 offset 个元素并且只获取前count个元素

zrevrangebyscore 不仅是按照元素分数从大往小的顺序给出结果,而且他的 min 和max 的参数的顺序和 zrangebyscore 命令是相反的


增加某个元素的分数

zincrby key increment member

zincrby 命令可以增加一个元素的分数,返回值是更改后的分数,例如想给peter 加 4 分

zincrby scoreborder 4 peter

increment 也可以是负数表示减分

zincrby scoreborder -4 peter

如果指定元素不存在,redis 在执行命令前会先建立它并将他的值赋为0在执行操作


获得集合中元素的数量

zcard key

当 key 存在且是有序集类型时,返回有序集的基数。当 key 不存在时,返回 0 。


获得指定分数范围内的元素个数

zcount key min max

zcount 命令的 min max 参数的特性与 zrangebyscore 命令中的一样


删除一个或多个元素

zrem key member [ member .... ]

zrem 命令的返回值是成功删除的元素数量(不包含本来就不存在的元素)


按照排名范围删除元素

zremrangebyrank key start stop

按照元素分数从小到大的顺序(即索引 0 表示最小的值)删除在指定排名范围内的所有元素,并返回删除元素的数量


按照分数范围删除元素

zremrangebyscore key min max

zremrangebyscore 命令删除指定分数范围内的所有元素,参数 min 和 max 的特性和 zrangebyscore 命令中的一样,返回值是删除元素的个数


获得元素的排名

zrank key member

zrank 命令会按照元素分数从小到大的顺序获得指定的元素排名(从 0 开始,即分数最小的元素排名为0)

zrevrank key member

zrebrank 命令则正好相反,分数最大的元素排名为0


计算有序集合的交集

zinterstore destination numkeys key [ key ... ] [ weights weight [ weight ... ] ] [ aggregate SUM | MIN | MAX ]

zinterstore 命令用来计算多个有序集合的交集病将结果存储在 destination 键中(同样以有序集合类型存储),返回值为 destination 键中元素的个数,destination 键中元素的分数是由 aggregate 参数决定的

1. 当 aggregate 是 SUM (也就是默认值),destination 键中元素的分数是每个参与计算的集合中该元素分数的和

2.当 aggregate 是 MIN 时,destination 键中元素的分数是参与计算的集合中该元素分数最小值

3.当 aggregate 是 MAX 是,destination 键中元素的分数是参与计算的集合中该元素分数最大值

zinterstore 命令还能通过 weights 参数设置每个集合的权重,每个集合在参与计算时元素的分数会被乘上该集合的权重


计算集合间的并集

zunionstore

用法与 zinterstore 命令的用法一样


-END-

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-12-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微卡智享 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 Redis®
腾讯云数据库 Redis®(TencentDB for Redis®)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档