88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令

本次讲解要点:
** 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添加一个或多个元素。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第1张图片

SCARD key: 返回key对应的Set中元素的个数。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第2张图片

SDIFF key [key …]: 计算多个Set之间的差值。
所谓差值,其实就是减去两个Set之间的公共部分(交集)
该命令对于两个key对应Set本身并没有修改,只是该命令会返回它们的差值。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第3张图片

SDIFFSTORE destination key [key …]: SDIFF的存储版本,将多个Set的差值保存到destination中。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第4张图片

SINTER key [key …]: 返回给定Set的交集。
该命令对于两个key对应Set本身并没有修改,这是该命令会返回它们的交集。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第5张图片

SINTERSTORE destination key [key …]: SINTER的存储版本,将给定Set的交集保存到destination中。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第6张图片

SISMEMBER key member: 判断member是否为key对应Set的元素。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第7张图片

SMEMBERS key: 返回key对应Set的全部元素。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第8张图片

SMOVE source destination member: 将source中的member某个元素移到destination中。
如果destination 对应Set不存在,该命令会创建一个新的Set。
不能移动自定义的元素个数
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第9张图片

SPOP key [count]: 弹出key对应Set中随机的一个元素。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第10张图片
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第11张图片

SRANDMEMBER key [count]: 返回key对应Set中随机的count个元素(不删除元素)。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第12张图片

SREM key member [member …]: 删除key对应Set中的一个或多个元素。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第13张图片

SUNION key [key …]: 计算给定Set的并集。
并集:将多个Set拼接在一起,但多个Set重复的元素只保留一份。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第14张图片

SUNIONSTORE destination key [key …]: SUNION的存储版本,将给定Set的并集保存到destination中。
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第15张图片

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 用来表示每次遍历的元素个数,但是并不能精确控制所返回的元素的个数
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第16张图片

88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第17张图片
count 用来表示每次遍历的元素个数,但是并不能精确控制所返回的元素的个数
解释:
count控制的是底层hash Slot的值,count控制要遍历底层Hash Slot的个数。
从外观上来看,此处设置的count只是一个建议值,并不代表Redis此次遍历会返回的元素个数。

set 底层是通过 hash 表来实现的。
hash表 的底层其实就是一个数组。
hash表就是一个数组,数组的每一个元素就是一个slot
88、Redis 的 value 所支持的数据类型(String、List、Set、Zset、Hash)---->Set相关命令_第18张图片

你可能感兴趣的:(springboot,redis,哈希算法,数据库)