Redis 中的五大基础类型(下)

简介: Redis 中的五大基础类型

1、新增点赞; sadd pub:msgid 点赞用户id1 点赞用户id2


2、取消点赞;srem pub:msgid 点赞用户id


3、展示所有点过赞的用户 smembers pub:msgid


4、点赞用户数统计,就是常见的待点赞的红色数数字 scard pub:msgid


5、判断某个朋友是否对楼主点过赞, sismember pub:msgid 用户id


微博好友关注社交关系


image.png


共同关注的人


sadd s1 1 2 3 4

sadd s2 2 3 6 8

sinter s1 s2


共同关注:我去某人的微博,马上获取和某人共同关注的人


我关注的人, 也关注了他(大家爱好相同)


我关注了华为余承东, 余承东也关注了张召动, 我和余总有共同的爱好


sadd s1 1 2 3 4 5

sadd s2 3 4 5 6 7

sismember s1 3

sismember s2 3


QQ内推可能认识的人


sadd s1 1 2 3 4 5

sadd s2 3 4 5 6 7


// 共同好友


sinter s1 s2


// 差集


sdiff s1 s2

sdiff s2 s1


zset 有序集合


常用命令


1、 向有序集合中添加一个元素和该元素的分数


2、 添加元素


  • ZADD key score member [score member ...]


3、 按照元素分数从小到达的顺序返回索引从 strat 到 stop 之间的所有元素


  • zrange key start stop [WITHSORES]


4、获取元素的分数


  • zscore key member [member ...]


5、删除元素


  • zrem key member [member ...]


6、 获取指定分数范围的元素


  • zrangebyscore key min max [WITHSCORES] [LIMIT offset count]


7、增加某个元素的分数


  • zincrby key increment member


8、 获取集合中元素的数量


  • zcard key


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


  • zcount key min max


10、按照排名范围删除元素


  • zremrangebyrank key start stop


11、获取元素的排名


  • 从小到大 zrank key member
  • 从大到小 zrevrank key member


应用场景


1、更具商品销售对商品进行排序显示


思路:定义商品销售排行榜(sorted set 集合),key 为 goods:sellsort, 分数为商品销售数量。


商品编号 1001 的销量是 9 , 商品编号 1002 的销量是 15


zadd goods:sellsort 9 1001 15 1002


有一个顾客又买了 2 件商品 1001 , 商品编号是 1001 数量增加 2


zincrby goods:sellsort 2 10001


求商品销量前 10 名


zrange goods:sellsort 0 10 withscores


image.png


2、 抖音热搜


image.png


1、点击视频


ZINCRBY hotavi:20220203 1 八百


ZINCRBY hotavi:20220203 15 八百 2 花木兰


2、展示当日排行前 10 条


zrevrange hotavi:20220203 0 9 withscores


参考资料



相关文章
|
负载均衡 NoSQL 算法
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
这篇文章是关于Java面试中Redis相关问题的笔记,包括Redis事务实现、集群方案、主从复制原理、CAP和BASE理论以及负载均衡算法和类型。
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
消息中间件 存储 监控
redis 的List类型 实现 排行榜
【10月更文挑战第8天】
291 2
|
存储 NoSQL Redis
redis-set类型
【10月更文挑战第6天】
307 1
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
241 3
|
消息中间件 分布式计算 NoSQL
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
251 2
|
JSON 缓存 NoSQL
redis序列化数据时,如何包含clsss类型信息?
通过配置 `com.fasterxml.jackson.databind.ObjectMapper` 的 `enableDefaultTyping` 方法,可以使序列化后的 JSON 包含类信息。
383 2
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树
|
消息中间件 NoSQL Kafka
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
1256 0