一、集合(Set)简介

  1. Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
  2. Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
  3. 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

二、常用命令

1、sadd sadd <key><value1><value2> 将一个或多个 member 元素加入到集合 key 中,已经存在的 member 元素将被忽略
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> sadd myset a b c d #往myset集合了添加值
(integer) 4 #返回4
127.0.0.1:6379> sadd myset a b c d #往myset集合了添加重复值
(integer) 0 #返回0
127.0.0.1:6379>
2、smembers smembers <key>取出该集合的所有值。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset #取出myset集合中所有的值
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379>
3、sismember sismember <key><value>判断集合是否为含有该值,有1,没有0
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset #查看当前集合中所有的值
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379> sismember myset d #判断当前集合是否存在d,存在返回1
(integer) 1
127.0.0.1:6379> sismember myset h #判断当前集合是否存在h,不存在返回0
(integer) 0
127.0.0.1:6379>
4、scard scard <key>返回该集合的元素个数。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset #查看当前集合元素个数
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379> scard myset
(integer) 4
5、srem srem <key><value1><value2> .... 删除集合中的某个元素。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset
1) "c"
2) "d"
3) "b"
4) "a"
127.0.0.1:6379> srem myset b #移除集合中存在的值
(integer) 1
127.0.0.1:6379> srem myset h #移除集合中不存在的值。返回0
(integer) 0
127.0.0.1:6379>
6、spop spop <key> 随机从该集合中吐出一个值。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> spop myset 1 #在当前集合随机弹出一个值
1) "c"
127.0.0.1:6379> spop myset 2 #再当前集合随机弹出两个值
1) "a"
2) "b"
127.0.0.1:6379> smembers myset #查看当前集合剩余的值
1) "d"
7、srandmember srandmember <key><n>随机从该集合中取出n个值。不会从集合中删除 。
127.0.0.1:6379> keys *
1) "myset"
127.0.0.1:6379> smembers myset
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> srandmember myset 2 #随机在集合中去取出2个值
1) "b"
2) "a"
127.0.0.1:6379> smembers myset #查看值是否被删除
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379>
8、smove smove <source> <destination> value把集合中一个值从一个集合移动到另一个集合
127.0.0.1:6379> sadd source a b c d					#在source里添加值
(integer) 4
127.0.0.1:6379> sadd destination 1 2 3 4 #在目标destination添加值
(integer) 4
127.0.0.1:6379> smembers source
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> smembers destination
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> smove source destination a #将source里面的a移动到destination集合里
(integer) 1
127.0.0.1:6379> smembers source #查看source集合
1) "d"
2) "c"
3) "b"
127.0.0.1:6379> smembers destination #查看destination集合里的元素
1) "4"
2) "3"
3) "2"
4) "1"
5) "a"
127.0.0.1:6379>
9、sinter sinter <key1><key2>返回两个集合的交集元素。
127.0.0.1:6379> sadd k1 1 2 3 a b c
(integer) 6
127.0.0.1:6379> sadd k2 a b c 4 5 6
(integer) 6
127.0.0.1:6379> smembers k1
1) "a"
2) "1"
3) "3"
4) "c"
5) "b"
6) "2"
127.0.0.1:6379> smembers k2
1) "4"
2) "b"
3) "a"
4) "6"
5) "c"
6) "5"
127.0.0.1:6379> sinter k1 k2 #返回两个集合公共的元素
1) "a"
2) "c"
3) "b"
10、sunion sunion <key1><key2>返回两个集合的并集元素。
127.0.0.1:6379> sadd k1 1 2 3 a b c
(integer) 6
127.0.0.1:6379> sadd k2 a b c 4 5 6
(integer) 6
127.0.0.1:6379> smembers k1
1) "a"
2) "1"
3) "3"
4) "c"
5) "b"
6) "2"
127.0.0.1:6379> smembers k2
1) "4"
2) "b"
3) "a"
4) "6"
5) "c"
6) "5"
127.0.0.1:6379> sunion k1 k2 #k1与k2的并集
1) "c"
2) "4"
3) "b"
4) "2"
5) "a"
6) "1"
7) "6"
8) "5"
9) "3"
11、 sdiff sdiff <key1><key2>返回两个集合的差集元素(key1中的,不包含key2中的)
127.0.0.1:6379> sadd k1 1 2 3 a b c
(integer) 6
127.0.0.1:6379> sadd k2 a b c 4 5 6
(integer) 6
127.0.0.1:6379> smembers k1
1) "a"
2) "1"
3) "3"
4) "c"
5) "b"
6) "2"
127.0.0.1:6379> smembers k2
1) "4"
2) "b"
3) "a"
4) "6"
5) "c"
6) "5"
127.0.0.1:6379> sdiff k1 k2 #返回k1集合与k2集合的差集(用k1集合减去k1与k2的交集)
1) "1"
2) "2"
3) "3"

三、总结

  1. Redis 的集合相当于 Java 语言里面的 HashSet,它内部的键值对是无序的唯一的。它的内部实现相当于一个特殊的字典,字典中所有的 value 都是一个值 NULL。
  2. 当集合中最后一个元素移除之后,数据结构自动删除,内存被回收。set 结构可以用来存储活动中奖的用户 ID,因为有去重功能,可以保证同一个用户不会中奖两次。
  3. set有交集、并集和补集,可以实现好友像好友推荐功能。
  4. list集合不具有唯一性,set是不重复的,保证唯一性。

7、Redis五大数据类型---集合(Set)的更多相关文章

  1. Redis五大数据类型的常用操作

    在上一篇博文<centos安装redis>中,已经详细介绍了如何在centos上安装redis,今天主要介绍下Redis五大数据类型及其五大数据类型的相关操作. Redis支持五种数据类型 ...

  2. 一文搞定Redis五大数据类型及应用场景

    本文学习知识点 redis五大数据类型数据类型:string.hash.list.set.sorted_set 五大类型各自的应用场景 @TOC 1. string类型 1-1 string类型数据的 ...

  3. redis 五大数据类型使用

    redis 五大数据类型使用 字符串str 单个值 127.0.0.1:6379> set name pp # 设置键值[O(1)] OK 127.0.0.1:6379> setex na ...

  4. 《Redis入门指南(第二版)》读书思考总结之Redis五大数据类型

    热身:系统级命令 1. 获得符合规则的键名列表 KEYS pattern 模式匹配 产品的缓存:product+"."+....;  => keys product* 订单的 ...

  5. Redis五大数据类型详解

    关于Redis的五大数据类型,它们分别为:String.List.Hash.Set.SortSet.本文将会从它的底层数据结构.常用操作命令.一些特点和实际应用这几个方面进行解析.对于数据结构的解析, ...

  6. redis五大数据类型以及常用操作命令

    Redis的五大数据类型 String(字符串) string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value.string类型是二进制安全的.意 ...

  7. 四:Redis五大数据类型

    Redis的五大数据类型 1.string(字符串) string是Redis最基本的类型,你可以理解成与menmcached一模一样的类型,一个key对应一个value string类型是二进制安全 ...

  8. 细谈Redis五大数据类型

    文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. 上一篇文章有提到,Redis中使用最频繁的有5种数据类型:String.List.Hash.Set.SortS ...

  9. Redis五大数据类型以及操作

    目录: 一.redis的两种链接方式 二.redis的字符串操作(string) 三.redis的列表操作(list) 四.redis的散列表操作(类似于字典里面嵌套字典) 五.redis的集合操作( ...

随机推荐

  1. Debug代码调试

    Debug代码调试 第一步在代码左侧先点一个红点 第二步右键选择Debug运行 第三步点击Step Into按键分步进行 练习题: s2 = 'python python python python ...

  2. 行星万象表白墙微信小程序、社交微信小程序,后台完整,支持多区域运营,扫码体验。

    简介 中国目前大概有5000个表白墙,累计用户近3000万,是一个庞大的群体,但现在大都以微信朋友圈为基础进行信息中转,但是这种模式经营者和用户都不友好,尤其是经营者无法变现,用户无法公开评论,这些种 ...

  3. <C#任务导引教程>练习一

    //1,定位显示ASCI码值为30到119的字符using System;class Program{    static void Main()    {        int i, n = 0;  ...

  4. Python学习手册(第四版)——使用入门(自学用)

    Python的优点 -可读性 -可移植性 -不是一个独立的工具,可以调用各种库,同时也可以被调用等等 -使编程变得很有趣 -面向对象 -可混合 Python的理念 随便找的一张图 脚本语言? Pyth ...

  5. 更通俗的理解JS原型链

    最近在网上看到一篇理解原型链的,感觉非常好非常通俗易懂,拿来记录一下~: 1)人是人他妈生的,妖是妖他妈生的.人和妖都是对象实例,而人他妈和妖他妈就是原型.原型也是对象,叫原型对象. 2)人他妈和人他 ...

  6. CF1562E Rescue Niwen!

    开始的时候只会一个\(O(n^2log)\) 即做出所有的\(n^2\)串,显然可以用\(SAM\)来进行这样一个排序,然后\(log\)做. 但这种题我们显然要找一些友好的性质: 我们发现字符串的比 ...

  7. Codeforces 856D - Masha and Cactus(树链剖分优化 dp)

    题面传送门 题意: 给你一棵 \(n\) 个顶点的树和 \(m\) 条带权值的附加边 你要选择一些附加边加入原树中使其成为一个仙人掌(每个点最多属于 \(1\) 个简单环) 求你选择的附加边权值之和的 ...

  8. CSS浮动效果

    #div1{ background-color: yellow; width: 150px; height:150px; position: absolute; top:150px; left: 15 ...

  9. goto 的用法

    #include <stdio.h> int main() { printf("go to cpy \n"); goto FLASH_CPY; printf(" ...

  10. C语言中储存的大小端问题

    一.大小端定义 研究变量的高低字节:从左往右看,字节序递增,也就是最右边是最低字节,最右边是最高字节.如 int i = 0x01020304, 01是高字节,04是低字节.如果是字符串如char a ...