Redis第七弹-Set与ZSET基本操作,Set(集合特点)SADD key member(注意这个key,必须是你自定义名字,不能用key)​编辑SMEMBERS key-查询所有的key

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis第七弹-Set与ZSET基本操作,Set(集合特点)SADD key member(注意这个key,必须是你自定义名字,不能用key)​编辑SMEMBERS key-查询所有的key

Set(集合特点)

1.集合中元素是无序的

2.集合中的元素不可以重复

SADD key member(注意这个key,必须是你自定义名字,不能用key)

SMEMBERS key-查询所有的key中的值

spop key [count]不写的时候,随机去删除一个,写的时候,写几个我就去删除几个


SMOVE source destination member。把member从source中删除再移动到destination中(假如移动到元素在source中不存在,此时返回0表示移动失败)

SREM key member删除1个或多个member

集合间操作交集(inter   和数学上的一样),并集(union),差集(diff)

SINTERSTORE交集,并把交集存储到一个key中

SUNIONSTORE并集,把并集存储到一个key中

SDIFFSTORE-差集,存储差集(注意那个在左边,他的差集,就是从他现有的位置做差集)

set内部编码:

intset(整数集合)

为了节省空间,做的特定优化,元素均为整数,且元素个数不是很多的情况下。

hashtable(哈希表)

set应用场景:用set保存用户的标签

1.set方便算交集,易找到两个用户之间的公共标签

2.计算用户间的共同好友

3.用set统计UV

PV -page view用户每次访问服务器,每次都会产生一个PV

UV -user view每个用户访问服务器,都会产生一个UV

ZSET-有序集合(升序/降序)

排序的规则:引入的score浮点类型,按照分数大小进行升序/降序排序,使用zadd往有序结合中添加元素和分数

ZADD key score memeber(不加NX|XX选项时,member不存在,会达到新member的效果

XX:只更新当前已经存在,NX:只添加新的,老的不去处理

CH:描述返回值,返回什么信息(包括修改的个数,影响zadd返回值)

ZINCRBY key score members-针对key的元素的分数+score

ZSET-内部跳表(内部升序排列)如果分数相同则会按照元素字符串的字典序

set list添加都是O(1)但是zset添加则需要Olog(N)(因为有顺序)

redis内部存储数据的时候,按二进制方式存储的,这也意味着redis服务器并不负责字符编码

由于这里我们存储的是汉字,他是由二进制存储的,所以会\x...

redis-cli --raw(使用字符集utf-8编码方式而不是ac码)

ZCARD key-获取一个元素的个数

ZCount查找指定score区间,元素的个数(两个闭区间)

开区间的设置方法

zcount key (95,(97

zset内部会记录当前每个元素的排行次序,max -min这种

inf无穷大

-inf负无穷大

ZRANGE key start stop  [with score]-按照分数的升序排列

ZREVRANGE-按照分数的降序排列

ZRANGEBYSCORE-按照分数区间,来去查找元素。

ZPOPMAX--删除并且返回分数最高的count个元素

分数是主要因素,如果分数相同则按照字典序,调用的是通用删除函数,但是其实也可以把最后一个元素标记,直接去尾删(官方针对这个没去优化,使用的次数较少)

BZPOPMAX key [timeout]-实现类似于阻塞队列的效果

zpopmin删除有序集合中最小的元素

BZPOPMIN key删除最小元素(阻塞版本)

ZRANK获取指定元素排名

ZREVRANK-获取指定元素的排名,从后往前数

ZSCORE查询指定元素的分数

ZREM key member 移除对应元素

ZREMRANGEBYSCORE-按照指定分数区间去删除

ZINCRBY 针对元素的分数进行增加

集合间运算

inter:交集

union:并集

diff:差集

ZINTERSTORE进行交集运算后,存储在一个key中

后面的参数:

[weight]权重 aggregate <sum(用于描述分数,默认是用它,作用是求和,下图的分数,是两个key中分数求和后的分数)|MIN|MAX>

其中的最小值,最大值也同理,就不举例了

ZUNIONSTORE :获取其中并集,然后存储到key 中


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
相关文章
|
6月前
|
缓存 NoSQL Java
Redis应用—6.热key探测设计与实践
热key问题在高并发系统中可能导致数据层和服务层的严重瓶颈,如Redis集群瘫痪和用户体验下降。为解决此问题,京东开发了JdHotkey热key探测框架,具备实时性、准确性、集群一致性和高性能等特点。该框架由etcd集群、Client端jar包、Worker端集群和Dashboard控制台组成,通过分布式计算快速识别热key并推送至应用内存,有效减轻数据层负载,提升服务性能。JdHotkey适用于多种场景,安装部署简便,支持毫秒级热key探测和集群一致性维护。
287 61
Redis应用—6.热key探测设计与实践
|
3月前
|
NoSQL 测试技术 Redis
Redis批量删除Key的三种方式
Redis批量删除Key是优化数据库性能的重要操作,本文介绍三种高效方法:1) 使用通配符匹配(KEYS/SCAN+DEL),适合不同数据规模;2) Lua脚本实现原子化删除,适用于需要事务保障的场景;3) 管道批量处理提升效率。根据实际需求选择合适方案,注意操作不可逆,建议先备份数据,避免内存溢出或阻塞。
|
10月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
4234 113
|
10月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
534 113
|
8月前
|
缓存 NoSQL 架构师
Redis批量查询的四种技巧,应对高并发场景的利器!
在高并发场景下,巧妙地利用缓存批量查询技巧能够显著提高系统性能。 在笔者看来,熟练掌握细粒度的缓存使用是每位架构师必备的技能。因此,在本文中,我们将深入探讨 Redis 中批量查询的一些技巧,希望能够给你带来一些启发。
620 23
Redis批量查询的四种技巧,应对高并发场景的利器!
|
6月前
|
存储 NoSQL Redis
投行系统的毫秒级榜单响应:如何用Redis ZSET破解同分排序难题?
通过Redis的ZSET数据结构和更新时间戳,解决投行交易系统实时排行榜中同分跳变的问题。具体方案为:将交易量作为整数部分,更新时间戳作为小数部分,确保同分时按最新更新排序,实现实时、高效、无需应用层干预的排行榜功能。一句话总结:通过Redis ZSET加更新时间戳,解决百万交易排行榜实时显示及同分难题。
|
8月前
|
NoSQL API Redis
在C程序中实现类似Redis的SCAN机制的LevelDB大规模key分批扫描
通过上述步骤,可以在C程序中实现类似Redis的SCAN机制的LevelDB大规模key分批扫描。利用LevelDB的迭代器,可以高效地遍历和处理数据库中的大量键值对。该实现方法不仅简单易懂,还具有良好的性能和扩展性,希望能为您的开发工作提供实用的指导和帮助。
108 7
|
10月前
|
消息中间件 缓存 NoSQL
Redis 高并发竞争 key ,如何解决这个难点?
本文主要探讨 Redis 在高并发场景下的并发竞争 Key 问题,以及较为常用的两种解决方案(分布式锁+时间戳、利用消息队列)。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
Redis 高并发竞争 key ,如何解决这个难点?
|
10月前
set集合
HashSet(无序,唯一): 基于 HashMap 实现的,底层采用 HashMap 来保存元素。 LinkedHashSet: LinkedHashSet 是 HashSet 的子类,并且其内部是通过 LinkedHashMap 来实现的。 TreeSet(有序,唯一): 红黑树(自平衡的排序二叉树)。