集合与有序集合

集合分为有序集合 (zset) 和无序集合 (set), 一般无序集合也直接说成集合

无序集合 (set)

无序集合(set)类型不允许有重复的元素,且存储无序,所以不能用下标获取元素。
一个集合最多可存 2^32-1 个元素。
Redis 的集合除了增删改查还支持取交集、并集、差集。

集全内操作命令


sadd key element [element ...] // 返回结果为添加成功的元素个数

srem key element [element ...] // 删除多个元素, 返回成功的个数

scard key // 返回元素个数, O(1)

sismember key element // 判断元素是否存在

srandmember key [count] // 随机返回指定个数个元素

spop key // 随机弹出元素, 返回弹出的元素 (3.2 版本后支持 [count] 参数)

smembers key // 获取集合所有元素, 返回结果无序 (元素过多可能会阻塞)

  • srandmember 和 spop 都是随机返回元素, 两者的不同是, spop 会从集合中删除元素
  • smembers, lrange, hgetall 都属于比较重的命令, 如果元素过多存在阻塞的可能. (可以用 sscan 命令)

集合间操作命令

sinter key [key ...] // 获取多个集合的交集
sunion key [key ...] // 获取并集
sdiff key [key ...] // 获取差集
sinterstore des key [key ...] // 求 keys 的交集, 并存入 des 中
sunionstore des key [key ...] // 并集, 并存入 des
sdiffstore des key [key...] // 差集, 并存入 des

使用场景

标签

  • 给用户打标签, 以及给标签集添加用户
  • 删除用户身上的标签, 删除标签集的用户
  • sinter 计算共同爱好的用户 (社交需求)

两个操作应该在同一事务中执行,

抽奖

  • spop: 用于奖品数量固定的抽奖
  • srandmember: 用于奖品数量不限的抽奖

有序集合 (zset)

有序集合, 有序且不可重复, 按分数 (score) 排序

有序集合内命令

// 增
zadd key score member [score member ...] // 添加成员, 返回成功添加的个数, O(log(n))
// 改
zincrby key increment member // 增加成员的分数
// 查
zcard key // 返回成员个数, O(1)
zscore key member // 返回某个成员的分数
zrand key member // 由小向大排序, 返回某成员的排名
zrevrand key member // 由大向小排序, 返回某成员的排名
zrange key start end [withscores] // 由小到大, 返回指定排名范围的成员, 前后皆闭, 下标从 0 开始,
zrevrange key start end [withscores] // 由大到小, [withscores] 可选, 是否返回分数
zcount key min max // 返回分数范围内的成员个数
zRangeByScore key min max [withscores] [limit offset count] // 返回指定分数范围的成员
zRevRangeByScore key max min [withscores] [limit offset count]
// 删除成员
zrem key member [member ...] // 删除成员
zRemRangeByRank key start end // 按升序删除指定排名的成员, 返回删除成功的个数
zRemRangeByScore key min max // 删除指定分数区间的成员
  • zadd 有四个选项, nx, xx, ch, incr.
    • nx member 必须不存在才可成功
    • xx member 必须存在才可成功
    • ch 返回此次操作后元素和分数发生变化的个数
    • incr 对 score 做增加. 相当于用 zincrby
  • zadd 有序了后, 也发生了代价, 复杂度 O(log(n))
  • min, max 支持开区间 (小括号) 和 闭区间 (中括号), 还支持负无穷 (-inf) 和 正无穷 (+inf)

集合间操作

zInterStore des numKeys key [key ...] [weights weight [weight ...]] [aggregate sum|min|max] // 交集
zUnionStore des numKeys key [key ...] [weights weight [weight ...]] [aggregate sum|min|mua] // 并集
  • des 表示目的, 计算结果存入该键
  • numKeys 需要做交集计算的键的个数
  • key [key ...] 需要做交集计算的键
  • weights weight [weight ...] 每个键的权重, 默认为 1, 交集计算时, 每个键中的每个 member * 对应权重
  • aggregate sum|min|max 计算成员交集后, 分值可以按 sum (取和), min (取最小值), max (取最大值) 汇总, 默认 sum

使用场景

排行榜系统 (如点赞榜)

  • zadd 添加用户及点赞数
  • zIncrBy 增加/减少赞数
  • zrem 作弊等处罚, 删除所有点赞数
  • zRevRange 展示获取赞数最多的前多少名

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