本次讲解要点:
** Set相关命令:是指value中的数据类型**
启动redis服务器:
打开小黑窗:
C:\Users\JH>e:
E:>cd E:\install\Redis6.0\Redis-x64-6.0.14\bin
E:\install\Redis6.0\Redis-x64-6.0.14\bin>redis-server.exe redis.windows.conf
启动redis客户端:
小黑窗:redis-cli
★ Redis的数据类型(都是针对Redis的value而言)
redis和map差不多。
Map 只能保存在内存中,
redis可以保存在磁盘。
Redis的key都是String
▲ value支持如下5种数据类型:
String: 最基本的数据类型,可保存任何的数据。
List: 元素是String的有序集合,集合内的元素可以重复。
Set: 元素是String的无序集合,集合内的数据不能重复。
Zset: 元素是String的有序集合,集合内的数据不能重复。
Hash: 也是key-value集合(类似Java的Map),key和value都是String类型的数据。这种类型主要用于保存对象。
Redis为不同数据类型提供了不同的操作命令,因此特定类型的数据需要使用对应类型的命令来执行操作。
source:源
destination:目标
★ Set相关的命令:
当 value 是 Set类型 时,需要使用 Set相关的命令进行操作。
Set代表无序、元素不能重复的集合,因此Set中的元素都是唯一的。
Set最多可包含2^32-1个元素。Set底层其实是通过Hash表实现的,因此它的删除、查找的复杂度都是 O(1),性能很好。
SADD key member [member …]: 向key对应的Set添加一个或多个元素。
SCARD key: 返回key对应的Set中元素的个数。
SDIFF key [key …]: 计算多个Set之间的差值。
所谓差值,其实就是减去两个Set之间的公共部分(交集)
该命令对于两个key对应Set本身并没有修改,这是该命令会返回它们的差值。
SDIFFSTORE destination key [key …]: SDIFF的存储版本,将多个Set的差值保存到destination中。
SINTER key [key …]: 返回给定Set的交集。
该命令对于两个key对应Set本身并没有修改,这是该命令会返回它们的交集。
SINTERSTORE destination key [key …]: SINTER的存储版本,将给定Set的交集保存到destination中。
SISMEMBER key member: 判断member是否为key对应Set的元素。
SMEMBERS key: 返回key对应Set的全部元素。
SMOVE source destination member: 将source中的member元素移到destination中。
如果destination 对应Set不存在,该命令会创建一个新的Set。
SPOP key [count]: 弹出key对应Set中随机的一个元素。
SRANDMEMBER key [count]: 返回key对应Set中随机的count个元素(不删除元素)。
SREM key member [member …]: 删除key对应Set中的一个或多个元素。
SUNION key [key …]: 计算给定Set的并集。
并集:将多个Set拼接在一起,但多个Set重复的元素只保留一份。
SUNIONSTORE destination key [key …]: SUNION的存储版本,将给定Set的并集保存到destination中。
SSCAN key cursor [MATCH pattern] [COUNT count]: 使用cursor遍历key对应的Set。
pattern指定只遍历匹配pattern的元素,count指定最多只遍历count个元素。
cursor代表一个游标,记录了遍历Set的位置,关于cursor的要点:
▲ 第一次遍历时通常将cursor设为0。
▲ 执行该命令后会返回当前的cursor值(记录了遍历的位置),只要该cursor不为0,表明遍历还未结束。
▲ 如果你希望继续接着上一次sscan的结果继续遍历,你传入的cursor就应该是上次sscan所返回的cursor值。
count参数的默认值为10,count并不能精确控制所返回的元素的个数。
count控制的是底层hash Slot的值,count控制要遍历底层Hash Slot的个数。
从外观上来看,此处设置的count只是一个建议值,并不代表Redis此次遍历会返回的元素个数。
演示
SADD key member [member …]: 向key对应的Set添加一个或多个元素。
SCARD key: 返回key对应的Set中元素的个数。
SDIFF key [key …]: 计算多个Set之间的差值。
所谓差值,其实就是减去两个Set之间的公共部分(交集)
该命令对于两个key对应Set本身并没有修改,只是该命令会返回它们的差值。
SDIFFSTORE destination key [key …]: SDIFF的存储版本,将多个Set的差值保存到destination中。
SINTER key [key …]: 返回给定Set的交集。
该命令对于两个key对应Set本身并没有修改,这是该命令会返回它们的交集。
SINTERSTORE destination key [key …]: SINTER的存储版本,将给定Set的交集保存到destination中。
SISMEMBER key member: 判断member是否为key对应Set的元素。
SMEMBERS key: 返回key对应Set的全部元素。
SMOVE source destination member: 将source中的member某个元素移到destination中。
如果destination 对应Set不存在,该命令会创建一个新的Set。
不能移动自定义的元素个数
SPOP key [count]: 弹出key对应Set中随机的一个元素。
SRANDMEMBER key [count]: 返回key对应Set中随机的count个元素(不删除元素)。
SREM key member [member …]: 删除key对应Set中的一个或多个元素。
SUNION key [key …]: 计算给定Set的并集。
并集:将多个Set拼接在一起,但多个Set重复的元素只保留一份。
SUNIONSTORE destination key [key …]: SUNION的存储版本,将给定Set的并集保存到destination中。
SSCAN key cursor [MATCH pattern] [COUNT count]: 使用cursor遍历key对应的Set。
pattern指定只遍历匹配pattern的元素,count指定最多只遍历count个元素。
cursor代表一个游标,记录了遍历Set的位置,关于cursor的要点:
▲ 第一次遍历时通常将cursor设为0。
▲ 执行该命令后会返回当前的cursor值(记录了遍历的位置),只要该cursor不为0,表明遍历还未结束。
▲ 如果你希望继续接着上一次sscan的结果继续遍历,你传入的cursor就应该是上次sscan所返回的cursor值。
count参数的默认值为10,count并不能精确控制所返回的元素的个数。
count控制的是底层hash Slot的值,count控制要遍历底层Hash Slot的个数。
从外观上来看,此处设置的count只是一个建议值,并不代表Redis此次遍历会返回的元素个数。
count参数的默认值为10,count并不能精确控制所返回的元素的个数。
count 用来表示每次遍历的元素个数,但是并不能精确控制所返回的元素的个数
count 用来表示每次遍历的元素个数,但是并不能精确控制所返回的元素的个数
解释:
count控制的是底层hash Slot的值,count控制要遍历底层Hash Slot的个数。
从外观上来看,此处设置的count只是一个建议值,并不代表Redis此次遍历会返回的元素个数。
set 底层是通过 hash 表来实现的。
hash表 的底层其实就是一个数组。
hash表就是一个数组,数组的每一个元素就是一个slot