• 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此次遍历会返回的元素个数。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    演示

    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此次遍历会返回的元素个数。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    count参数的默认值为10,count并不能精确控制所返回的元素的个数。
    count 用来表示每次遍历的元素个数,但是并不能精确控制所返回的元素的个数
    在这里插入图片描述

    在这里插入图片描述
    count 用来表示每次遍历的元素个数,但是并不能精确控制所返回的元素的个数
    解释:
    count控制的是底层hash Slot的值,count控制要遍历底层Hash Slot的个数。
    从外观上来看,此处设置的count只是一个建议值,并不代表Redis此次遍历会返回的元素个数。

    set 底层是通过 hash 表来实现的。
    hash表 的底层其实就是一个数组。
    hash表就是一个数组,数组的每一个元素就是一个slot
    在这里插入图片描述

  • 相关阅读:
    Spark初学者出师未接身先死
    iNeuOS工业互联网操作系统,在线报表(Excel)开发工具
    中文Stable Diffusion模型太乙使用教程
    【听课笔记】复旦大学遗传学_10肿瘤遗传学
    【树莓派不吃灰】搭建Homeassistant 开源智能家居平台平台(非Hass OS搭建方式),记录搭建过程的各种坑
    循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(10) -- 在DataGrid上直接编辑保存数据
    【批处理DOS-CMD命令-汇总和小结】-环境变量、路径变量、搜索文件位置相关指令——set、path、where
    机器学习之决策树【西瓜书】
    tar 和 zip 打包压缩命令
    瑞吉外卖 —— 10、Redis
  • 原文地址:https://blog.csdn.net/weixin_44411039/article/details/133304578