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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 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


参考资料



相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
5月前
|
负载均衡 NoSQL 算法
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
这篇文章是关于Java面试中Redis相关问题的笔记,包括Redis事务实现、集群方案、主从复制原理、CAP和BASE理论以及负载均衡算法和类型。
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
|
2月前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
3月前
|
消息中间件 存储 监控
redis 的List类型 实现 排行榜
【10月更文挑战第8天】
53 2
|
3月前
|
存储 NoSQL Redis
redis-set类型
【10月更文挑战第6天】
58 1
|
3月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
35 3
|
3月前
|
消息中间件 分布式计算 NoSQL
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
37 2
|
2月前
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树
|
4月前
|
JSON 缓存 NoSQL
redis序列化数据时,如何包含clsss类型信息?
通过配置 `com.fasterxml.jackson.databind.ObjectMapper` 的 `enableDefaultTyping` 方法,可以使序列化后的 JSON 包含类信息。
63 2
|
3月前
|
消息中间件 NoSQL Kafka
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
226 0
|
6月前
|
Java
Redis19----RedisTemplate操作Hash类型
Redis19----RedisTemplate操作Hash类型