redis:set集合类型的操作(无序集合)
1. set集合类型的操作(无序集合)
集合具有无序性(没有顺序)、确定性(描述是确定的)、唯一性(没有重复的元素)
1.1. sadd key member [member ...]
语法:sadd key member [member ...]
作用:往集合key中添加元素
返回值:添加元素的个数
例:
127.0.0.1:6379> sadd fruit apple banana pear
(integer) 3
127.0.0.1:6379> sadd num 1 1
(integer) 1
1.2. smembers key
语法:smembers key
作用:返回集合key中所有的元素
例:
127.0.0.1:6379> smembers fruit
1) "pear"
2) "banana"
3) "apple"
127.0.0.1:6379> smembers num
1) "1"
1.3. srandmember key [count]
语法:srandmember key [count]
作用:返回集合key中随机的1个元素
例:
127.0.0.1:6379> smembers letter
1) "d"
2) "g"
3) "c"
4) "e"
5) "a"
127.0.0.1:6379> srandmember letter
"e"
127.0.0.1:6379> srandmember letter
"c"
127.0.0.1:6379> srandmember letter
"a"
127.0.0.1:6379> srandmember letter 2
1) "c"
2) "e"
127.0.0.1:6379> srandmember letter 3
1) "c"
2) "e"
3) "a"
127.0.0.1:6379> smembers letter
1) "d"
2) "g"
3) "c"
4) "e"
5) "a"
1.4. srem key member [member ...]
语法:srem key member [member ...]
作用:删除集合key中的member [member...]元素
返回值:忽略不存在的元素后,真正删除掉的元素的个数
例:
127.0.0.1:6379> smembers num
1) "1"
127.0.0.1:6379> srem num 1
(integer) 1
127.0.0.1:6379> smembers num
(empty list or set)
127.0.0.1:6379> srem fruit pear
(integer) 1
127.0.0.1:6379> smembers fruit
1) "banana"
2) "apple"
1.5. spop key [count]
语法:spop key [count]
作用:返回并删除集合key中1个随机的元素
例:
127.0.0.1:6379> sadd letter a b c d e f g
(integer) 7
127.0.0.1:6379> smembers letter
1) "c"
2) "d"
3) "g"
4) "b"
5) "e"
6) "a"
7) "f"
127.0.0.1:6379> spop letter
"b"
127.0.0.1:6379> smembers letter
1) "d"
2) "g"
3) "c"
4) "e"
5) "a"
6) "f"
127.0.0.1:6379> spop letter
"f"
127.0.0.1:6379> smembers letter
1) "d"
2) "g"
3) "c"
4) "e"
5) "a"
案例:
spop是返回并删除一个随机的元素,所以可以用来做抽奖,第一次spop出的可以作为第一名(一等奖),第二次spop出的可以作为第二名(二等奖)...
1.6. sismember key member
语法:sismember key member
作用:判断member是否是集合key中的元素
返回值:是返回1;不是返回0
例:
127.0.0.1:6379> smembers letter
1) "d"
2) "g"
3) "c"
4) "e"
5) "a"
127.0.0.1:6379> sismember letter a
(integer) 1
127.0.0.1:6379> sismember letter k
(integer) 0
127.0.0.1:6379> sismember letter 0
(integer) 0
1.7. scard key
语法:scard key
作用:返回集合key中元素的个数
例:
127.0.0.1:6379> smembers letter
1) "d"
2) "g"
3) "c"
4) "e"
5) "a"
127.0.0.1:6379> scard letter
(integer) 5
1.8. sinter key [key ...]
语法:sinter key [key ...]
作用:求出key [key ...]几个集合中的交集,并返回
例:
127.0.0.1:6379> sadd lisa c python java
(integer) 3
127.0.0.1:6379> sadd wang english python php
(integer) 3
127.0.0.1:6379> sadd poly python redis c++
(integer) 3
127.0.0.1:6379> sinter lisa wang poly
1) "python"
127.0.0.1:6379> sadd tom python java php redis
(integer) 4
127.0.0.1:6379> sinter tom poly
1) "redis"
2) "python"
1.9. sinterstore destination key [key ...]
语法:sinterstore destination key [key ...]
作用:求出key [key ...]几个集合中的交集,并赋给destination或存储在destination中
返回值:返回真正存储到destination中的元素的个数
例:
127.0.0.1:6379> smembers lisa
1) "python"
2) "java"
3) "c"
127.0.0.1:6379> smembers poly
1) "c++"
2) "redis"
3) "python"
127.0.0.1:6379> smembers tom
1) "redis"
2) "php"
3) "python"
4) "java"
127.0.0.1:6379> sinterstore lisa_tom lisa tom
(integer) 2
127.0.0.1:6379> smembers lisa_tom
1) "python"
2) "java"
1.10. sunion key [key ...]
语法:sunion key [key ...]
作用:求出key [key ...]几个集合的并集,并返回
例:
127.0.0.1:6379> sadd lisa c python java
(integer) 3
127.0.0.1:6379> sadd wang english python php
(integer) 3
127.0.0.1:6379> sadd poly python redis c++
(integer) 3
127.0.0.1:6379> sunion lisa wang
1) "python"
2) "c"
3) "java"
4) "php"
5) "english"
127.0.0.1:6379> sadd tom python java php redis
(integer) 4
127.0.0.1:6379> sunion lisa wang tom poly
1) "php"
2) "c"
3) "c++"
4) "redis"
5) "python"
6) "english"
7) "java"
1.11. sdiff key [key ...]
语法:sdiff key [key ...]
作用:求出key与[key ...]的差集
例:
127.0.0.1:6379> smembers lisa
1) "python"
2) "java"
3) "c"
127.0.0.1:6379> smembers tom
1) "redis"
2) "php"
3) "python"
4) "java"
127.0.0.1:6379> sdiff lisa tom
1) "c"
127.0.0.1:6379> sdiff tom lisa
1) "redis"
2) "php"
127.0.0.1:6379> smembers poly
1) "c++"
2) "redis"
3) "python"
127.0.0.1:6379> sdiff tom lisa poly
1) "php"
redis:set集合类型的操作(无序集合)的更多相关文章
- redis:order set有序集合类型的操作(有序集合)
1. order set有序集合类型的操作(有序集合) 有序集合是在无序集合的基础上加了一个排序的依据,这个排序依据叫score,因此声明一个集合为有序集合的时候要加上score(作为排序的依据) 1 ...
- Python集合类型的操作与应用
Python集合类型的操作与应用 一.Python集合类型 Python中的集合类型是一个包含0个或多个数据项的无序的.不重复的数据组合,其中,元素类型只能是固定数据类型,如整数.浮点数.字符串.元组 ...
- 四:redis的sets类型 - 相关操作(有序和无序集合)
================四十五种(有序和无序集合):sets种类(它是一个集)============= 简介: set它代表的集合.加入是随意添加----->无序集合 ...
- c#重点[集合类型]异常,数组,集合ArrayList,List<>,hashTable,hashtable泛型(Dictionary)
1.foreach[对一些数组或集合进行遍历] foreach(类型 变量名 in 集合对象){语句体} //定义一个数组 ,,,,, }; foreach(var i in sNum1) { Con ...
- [Swift]遍历集合类型(数组、集合和字典)
Swift提供了三种主要的集合类型,称为数组,集合和字典,用于存储值集合. 数组是有序的值集合. 集是唯一值的无序集合. 字典是键值关联的无序集合. Swift中无法再使用传统形式的for循环. // ...
- 三:redis的List类型相关操作
</pre><pre name="code" class="php" style="font-size: 14px;"&g ...
- redis:list列表类型的操作
1. list列表类型的操作 1.1. lpush/rpush key value [value ...] 链表的头部(左侧)或尾部(右侧)插入值 语法:lpush key value [value ...
- redis:string字符串类型的操作
1. string字符串类型的操作: 1.1. set 设置单个值 语法:set key value [EX seconds] [PX milliseconds] [NX|XX] 注: EX seco ...
- [redis] redis 对string类型数据操作
package com.xwolf.java.redis; import org.junit.Before; import org.junit.Test; import redis.clients.j ...
随机推荐
- 使用JDBC连接ElasticSearch6.3(ElasticSearch SQL JDBC)
使用JDBC连接ElasticSearch6.3(ElasticSearch SQL JDBC) https://blog.csdn.net/scgaliguodong123_/article/det ...
- IIS7 禁止目录运行脚本
早晨看博客说有人被黑了:http://www.cnblogs.com/sanshi/p/3150639.html 看回复建议禁用上传目录的脚本运行权限 在IIS6上还是比较容易的,直接右键--属性,把 ...
- 最大子数组(I, II, III,IV,V)和最大子数组乘积 (动态规划)
I 找一个连续最大子数组,sum加到nums[i], 如果前面子数组和<0则舍去,从头开始. class Solution { public: /** * @param nums: A list ...
- 【BZOJ2298】[HAOI2011]problem a
题解: 虽然也是个可以过得做法...但又没有挖掘到最简单的做法... 正解是发现这个东西等价于求不相交区间个数 直接按照右端点排序,然后贪心就可以O(n)过了 而我的做法是按照a排序(其实我是在模拟这 ...
- 如何在grails2.3.x中的fork模式下进行调试?-【grails】
grails2.3.x中默认情况下运行模式被设置成了fork模式,在这种模式下,大家会发现设置了断点后无法进行中断.这是由于fork模式造成的,因为在fork模式下,JVM新起了一个进程,这样调试器就 ...
- 【Android】修改Android 模拟器IMEI
修改Android 模拟器IMEI 在.....\android_sdk\tools文件下找到emulator-arm.exe,使用UltraEdit文本编辑器打开,搜索CGSN关键字,把000000 ...
- Codeforces 666E E - Forensic Examination SA + 莫队 + 线段树
E - Forensic Examination 我也不知道为什么这个复杂度能过, 而且跑得还挺快, 数据比较水? 在sa上二分出上下界, 然后莫队 + 线段树维护区间众数. #include< ...
- python3实现二叉树的遍历与递归算法解析
1.二叉树的三种遍历方式 二叉树有三种遍历方式:先序遍历,中序遍历,后续遍历 即:先中后指的是访问根节点的顺序 eg:先序 根左右 中序 左根右 后序 左右根 遍历总体思路:将树分成最小 ...
- Excel ——多表关联查询-vlookup
一.分组 需求: 在B列的右侧添加一列[消费分组]对B列的[月分组水平]进行分组,原始数据如下: 公式:在 C2 输入:“=VLOOKUP(B2,$E$1:$G$4,2,1)”,下拉填充. 提示:VL ...
- LoadRunner服务水平协议SLA
服务水平协议 (或称 SLA)是以插入的事务为设置对象来为负载测试场景定义的具体目标. Analysis 将这些目标与 LoadRunner在运行过程中收集和存储的性能相关数据进行比较,然后确定目标的 ...