redis zset类型

sorted set 是 set 的一个升级版本,它在 set 的基础上增加了一个顺序属性,和 set 一样 sorted  set 也是 string 类型元素的集合,不同的是每个元素都会关联一个 double类型的 score。sorted set 最经常的使用方式应该是作为索引来使用.我们可以把要排序的字段作为 score 存储,对象的 id当元素存储。

1 zadd

向名称为 key 的 zset 中添加元素 member,score 用于排序。如果该元素已经存在,则根据

score 更新该元素的顺序

127.0.0.1:6379> zadd zset 1 hello

(integer) 1

127.0.0.1:6379> zadd zset 2 world

(integer) 1

跟新2次

127.0.0.1:6379> zadd zset 3 world

(integer) 0

元素和score一起显示

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "world"

4) "3"

2 zrem

删除名称为 key 的 zset 中的元素 member

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "world"

4) "3"

127.0.0.1:6379> zrem zset world

(integer) 1

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3 zincrby

如果在名称为 key 的 zset 中已经存在元素 member,则该元素的 score 增加 increment;否则向集合中添加该元素,其 score 的值为 increment

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "world"

4) "3"

127.0.0.1:6379> zincrby zset 2 wxc

"2"

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

4 zrank

返回名称为 key 的 zset 中 member 元素的排名(按 score 从小到大排序)即下标下标
下标下标!

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrank zset wxc

(integer) 1

5 zrevrank

返回名称为 key 的 zset 中 member 元素的排名(按 score 从大到小排序)即下标。与zrank相反。

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrevrank  zset hello

(integer) 2

6 zrevrange

返回名称为 key 的 zset(按 score 从大到小排序)中的 index 从 start 到 end 的所有元素

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrevrange zset 0 -1 withscores

1) "world"

2) "3"

3) "wxc"

4) "2"

5) "hello"

6) "1"

7 zrangebyscore

返回集合中 score 在给定区间的元素(score从1开始)

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrangebyscore zset 2 4 withscores

1) "wxc"

2) "2"

3) "world"

4) "3"

8 zcount

返回集合中 score 在给定区间的数量

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zcount zset  2 3

(integer) 2

9 zcard

返回集合中元素个数

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zcard zset

(integer) 3

10 zscore

返回给定元素对应的 score

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zscore zset wxc

"2"

11 zremrangebyrank

删除集合中排名在给定下标区间的元素

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zremrangebyrank zset 2 2

(integer) 1

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

12 zremrangebyscore

删除集合中 score 在给定区间的元素

13 zunionstore

ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

计算给定的一个或多个有序集的并集,其中给定key的数量必须以numkeys参数指定,并将该并集(结果集)储存到destination。默认情况下,结果集中某个成员的score值是所有给定集下该成员score值之

      weight选项

              使用WEIGHTS选项,你可以为每个给定有序集分别指定一个乘法因子(multiplication factor),每个给定有序集的所有成员的score值在传递给聚合函数(aggregation function)之前都要先乘以该有序集的因子。默认为1。

      aggregate选项

              使用aggregate选项,你可以指定并集的结果集的聚合方式。默认使用的参数sum,可以将所有集合中某个成员的score值之作为结果集中该成员的score值;使用参数min,可以将所有集合中某个成员的最小score值作为结果集中该成员的score值;而参数max则是将所有集合中某个成员的最大score值作为结果集中该成员的score值。

127.0.0.1:6379> zrange programmer 0 -1 withscores

1) "peter"

2) "2000"

3) "jack"

4) "3500"

5) "tom"

6) "5000"

127.0.0.1:6379> zrange manager 0 -1 withscores

1) "herry"

2) "2000"

3) "mary"

4) "3500"

5) "bob"

6) "4000"

127.0.0.1:6379> zunionstore salary1 2 programmer manager weights 2 3

(integer) 6

127.0.0.1:6379> zrange salary1 0 -1 withscores

1) "peter"

2) "4000"

3) "herry"

4) "6000"

5) "jack"

6) "7000"

7) "tom"

8) "10000"

9) "mary"

10) "10500"

11) "bob"

12) "12000"

13 zunionstore

14 zinterstore

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

计算给定的一个或多个有序集的交集,其中给定key的数量必须以numkeys参数指定,并将该交集(结果集)储存到destination。默认情况下,结果集中某个成员的score值是所有给定集下该成员score值之和.其余同zunionstore

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容