一:Redis 集合(Set)

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

二:set常用操作

  1)sadd(name,values) name对应的集合中添加元素

  2)scard(name) 获取name对应的集合中元素个数

  3)sdiff(keys, *args)  在第一个name对应的集合中且不在其他name对应的集合的元素集合

  4)sdiffstore(dest, keys, *args) 获取第一个name对应的集合中且不在其他name对应的集合,再将其新加入到dest对应的集合中

  5)sinter(keys, *args) 获取多一个name对应集合的交集

  6)sinterstore(dest, keys, *args) 获取多一个name对应集合的并集,再讲其加入到dest对应的集合中

  7)sismember(name, value) 检查value是否是name对应的集合的成员

  8)smembers(name) 获取name对应的集合的所有成员

  9)smove(src, dst, value) 将某个成员从一个集合中移动到另外一个集合

  10)spop(name) 从集合的左侧(头部)移除一个成员,并将其返回

  11)srandmember(name, numbers) 从name对应的集合中随机获取 numbers 个元素

  12)srem(name, values) 在name对应的集合中删除某些值

  13)sunion(keys, *args)  获取多一个name对应的集合的并集

  14)sunionstore(dest,keys, *args) 获取多一个name对应的集合的并集,并将结果保存到dest对应的集合中

  15)sscan(name, cursor=0, match=None, count=None)

三:示例

[BEGIN] // ::
127.0.0.1:[]> select 选择会话窗口3
OK
127.0.0.1:[]> sadd n1 在集合中增加数据
(integer)
127.0.0.1:[]> sadd n1
(integer)
127.0.0.1:[]> sadd n1
(integer)
127.0.0.1:[]> sadd n1
(integer)
127.0.0.1:[]> SCARD n1 集合中有多少个元素
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> sadd n2
(integer)
127.0.0.1:[]> scard n2
(integer)
127.0.0.1:[]> sdiff n1 n2 两个集合的差集在n1中,不在n2中
) ""
) ""
127.0.0.1:[]> sdiff n3 n1 n2
(empty list or set)
127.0.0.1:[]> SDIFFSTORE n3 n1 n2 两个集合的差集在n1中,不在n2中并保存到n3中
(integer)
127.0.0.1:[]> SINTER n1 n2 交集在n1中,也在n2中
) ""
) ""
127.0.0.1:[]> SINTERSTORE n4 n1 n2 交集在n1中,也在n2中,并保存到n4中
(integer)
127.0.0.1:[]> SISMEMBER n1 判断元素在不在集合中
(integer)
127.0.0.1:[]> SMEMBERS n1 查看集合
) ""
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n2
) ""
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n3
) ""
) ""
127.0.0.1:[]> SMEMBERS n4
) ""
) ""
127.0.0.1:[]> smove n1 n2 把集合n1中元素1移动集合n2中
(integer)
127.0.0.1:[]> SMEMBERS n1
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n2
) ""
) ""
) ""
) ""
) ""
127.0.0.1:[]> spop n1 从集合左边移出一个元素并还回
""
127.0.0.1:[]> SMEMBERS n1
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2 从集体中随即取2个
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2
) ""
) ""
127.0.0.1:[]> SRANDMEMBER n2
) ""
) ""
127.0.0.1:[]> SREM n2 从集合中删除一个元素
(integer)
127.0.0.1:[]> SUNION n1 n2 两个集体并集
) ""
) ""
) ""
) ""
127.0.0.1:[]> SUNION n5 n1 n2 两个集体并集,并保存到n5中
) ""
) ""
) ""
) ""
127.0.0.1:[]> SMEMBERS n5
(empty list or set)
127.0.0.1:[]> SUNIONSTORE n5 n1 n2 两个集体并集,并保存到n5中
(integer)
127.0.0.1:[]> SSCAN n5 match
(error) ERR syntax error
127.0.0.1:[]> SSCAN n5 match
) ""
) ) "" [END] // ::

  

缓存数据库-redis数据类型和操作(set)的更多相关文章

  1. 缓存数据库-redis数据类型和操作(list)

    转: 狼来的日子里! 奋发博取 缓存数据库-redis数据类型和操作(list) 一:Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部( ...

  2. 缓存数据库-redis数据类型和操作(string)

    Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合) 一:String(字符串) string是redis ...

  3. 缓存数据库-redis数据类型和操作(sorted set)

    一:Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是 ...

  4. 缓存数据库-redis数据类型和操作(hash)

    一:Redis 哈希(Hash) Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象. Redis 中每个 hash 可以存储 232 - 1 ...

  5. 缓存数据库redis

    什么是Redis? Redis是一个TCP服务器,支持请求/响应协议. 在Redis中,请求通过以下步骤完成: 客户端向服务器发送查询,并从套接字读取,通常以阻塞的方式,用于服务器响应. 服务器处理命 ...

  6. Redis数据类型及其操作

    redis数据类型即操作 1. 字符串 set 设置字符串 格式: set key value 例子: set name kainhuck get 获取字符串的值 格式: get key 例子: ge ...

  7. 缓存数据库-redis介绍

    一:Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的 ...

  8. Redis数据类型和操作

    <"Java技术员"成长手册>,包含框架.存储.搜索.优化.分布式等必备知识,都收集在GitHub JavaEgg ,N线互联网开发必备技能兵器谱,欢迎指导 Redis ...

  9. 三个缓存数据库Redis、Memcache、MongoDB

    >>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境 ...

随机推荐

  1. BZOJ 2527 Meteors | 整体二分

    BZOJ 2527 Meteors 题意 一个圆环上有m个位置,编号为1~m,分别属于n个国家. 有k个时刻,每个时刻都会给圆环上的一个区间中每个位置的值加上一个数. 每个国家有一个目标,问对于每个国 ...

  2. 搭建hadoop集群

    hadoop的架构 HDFS + MapReduce = Hadoop MapReduce = Mapper + Reducer hadoop的生态系统 准备四个节点,系统版本为CentOS7.3 1 ...

  3. zookeeper和PHP zookeeper和kafka 扩展安装

    http://blog.csdn.net/fenglailea/article/details/52458737#t3   目录(?)[-] 安装zookeeper 1直接安装zookeeper无须编 ...

  4. SSM的整合

    框架的整合: 1. 依赖整合 aop的包: aspectweaver spring-aop spring核心: spring-context spring-web spring-webmvc spri ...

  5. Linux下vim 快捷键

    vim按d表示剪切 按dd剪切一行 vim命令:命令模式 /关键字 n继续向下查找vim的多行注释: 1.按ctrl + v进入 visual block模式 2.按上下选中要注释的行 3.按大写字母 ...

  6. 【数学】【CF1091D】 New Year and the Permutation Concatenation

    Description 给定一个数 \(n\),将所有 \(1~\sim~n\) 的排列按照字典序放到一个序列中,求有多少长度为 \(n\) 的子序列 \(p_i~p_{i+1}~\dots~p_{i ...

  7. Ansible8:Playbook循环

    目录 1.with_items 2.with_nested嵌套循环 3.with_dict 4.with_fileglob文件匹配遍历 5.with_lines 6.with_subelement遍历 ...

  8. IOS取消performSelector警告

    #pragma clang diagnostic push #pragma clang diagnostic ignored "-Warc-performSelector-leaks&quo ...

  9. CF&&CC百套计划2 CodeChef December Challenge 2017 Total Diamonds

    https://www.codechef.com/DEC17/problems/VK18 #include<cstdio> #include<iostream> #includ ...

  10. bzoj千题计划135:bzoj1066: [SCOI2007]蜥蜴

    http://www.lydsy.com/JudgeOnline/problem.php?id=1066 每个柱子拆成两个点 i<<1,i<<1|1,之间连流量为高度的边 如果 ...