NoSQL之Redis对set(集合)数据类型的操作之二

原创 2013年12月03日 13:51:51

7.sinter setkey1 setkey2 setkey3...:返回setkey1和setkey2的交集

127.0.0.1:6379> smembers setkey1
1) "world"
2) "hello"
3) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "2000"
127.0.0.1:6379> smembers setkey3
1) "3000"
127.0.0.1:6379> sinter setkey1 setkey2
1) "world"
2) "2000"
127.0.0.1:6379> sinter setkey1 setkey2 setkey3
(empty list or set)
127.0.0.1:6379> sadd setkey3 2000
(integer) 1
127.0.0.1:6379> sinter setkey1 setkey2 setkey3
1) "2000"

8.sinterstore setkey3 setkey1 setkey2..:将取到的交集存储到setkey3中。同sdiffstore

127.0.0.1:6379> sinterstore setkey5 setkey1 setkey2
(integer) 2
127.0.0.1:6379> smembers setkey5
1) "world"
2) "2000"

9.sunion setkey1 setkey2 setkey3....:取给定所有key的并集

127.0.0.1:6379> smembers setkey1
1) "world"
2) "hello"
3) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "2000"
127.0.0.1:6379> sunion setkey1 setkey2
1) "hello"
2) "2000"
3) "world"
4) "3000"

10.sunionstore setkey3 setkey1 setkey2...:将并集存到setkey3中

127.0.0.1:6379> sunionstore setkey6 setkey1 setkey2
(integer) 4
127.0.0.1:6379> smembers setkey6
1) "hello"
2) "2000"
3) "world"
4) "3000"

11.smove setkey1 setkey2 value:从setkey1中移除一个元素value到setkey2中。

127.0.0.1:6379> smembers setkey1
1) "world"
2) "hello"
3) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "2000"
127.0.0.1:6379> smove setkey1 setkey2 hello
(integer) 1
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "hello"
4) "2000"
127.0.0.1:6379> smembers setkey1
1) "world"
2) "2000"
127.0.0.1:6379> smove setkey1 setkey2 world
(integer) 1
127.0.0.1:6379> smembers setkey1
1) "2000"
127.0.0.1:6379> smembers setkey2
1) "3000"
2) "world"
3) "hello"
4) "2000"

大家仔细看一下上面的例子。就会发现,如果被移动的value在setkey2中已经存在,那么就相当于srem setkey1 value,仅仅是将value元素从setkey1中删除。

12.scard setkey:查看setkey集合中元素的个数

127.0.0.1:6379> smembers setkey1
1) "3000"
2) "2000"
127.0.0.1:6379> scard setkey1
(integer) 2

如果集合中没有元素那么返回integer 0

13.sismember setkey value:测试value是否是名称为setkey的集合的元素。返回1代表是,返回0代表不是。

127.0.0.1:6379> smembers setkey1
1) "3000"
2) "2000"
127.0.0.1:6379> sismember setkey1 2000
(integer) 1
127.0.0.1:6379> sismember setkey1 4000
(integer) 0

14.srandmember setkey:随机返回setkey的一个元素,但是不删除元素。

127.0.0.1:6379> smembers setkey1
1) "1000"
2) "4000"
3) "3000"
4) "5000"
5) "2000"
127.0.0.1:6379> srandmember setkey1
"5000"
127.0.0.1:6379> srandmember setkey1
"2000"
127.0.0.1:6379> srandmember setkey1
"1000"

最后强调一点,set里的数据是无序的。

通过学习并且测试上面的方法,一些细心的同学很容易能察觉到,用set来操作目前流行的sns或者微博的一些动态信息,实时消息或者实时推荐和分析都会非常方便。

相关文章推荐

NoSQL之Redis对zset(有序集合)数据类型的操作

一、简介 Sorted set(zset)是set的升级版本,它在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新得值调整顺序。可以理解为有两...

NoSQL之Redis对string数据类型的操作

一、简介   String是最简单的数据类型,一个Key对应一个Value,String类型是二进制安装的。Redis的string可以包含任何数据,比如jpg图片或者序列化的对象。...

NoSQL之Redis对数据类型hash的操作

一、简介 Redishash是一个string类型的field和value的映射表。它的添加、删除操作都是O(1)(平均)。hash特别适合存储对象,将一个对象存储在hash类型中会占用更少的内存,并...

redis: sorted set数据类型与操作

redis支持有序集合,即sorted sets数据类型。基本格式为: key --> member -- score     |  --> member -- score     so...

redis:set数据类型与操作

set是集合。我们可以向一个集合中“插入”,“删除”元素,也可以计算两个集合的“交集”,“并集”,及“作差”。如: 假设有集合A,B。 其中,A={1,2,3,4,5},B={4,5,6,7,8}...

Redis---set数据类型操作

一、概述:在Redis中,我们可以将Set类型看作为没有排序的字符集合,和List类型一样,我们也可以在该类型的数据值上执行添加、删除或判断某一元素是否存在等操作。需要说明的是,这些操作的时间复杂度为...

NoSQL之Redis技术(二):数据类型和命令

在上篇博客中我写了redis技术的入门以及环境的搭配,今天正式进入redis内容的介绍,今天主要介绍redis技术的数据类型和一些常用的命令。 我们说MySQL的数据类型可分为三大类,一是数值类型(...
  • qian_ch
  • qian_ch
  • 2017年03月27日 12:05
  • 444

Redis基础之数据类型(Set无序集合)

一、概述:    在Redis中,我们可以将Set类型看作为没有排序的字符集合,和List类型一样,我们也可以在该类型的数据值上执行添加、删除或判断某一元素是否存在等操作。需要说明的是,这些操作的时间...

Redis数据类型与指令详解之集合(t_set)

本文所引用的源码全部来自Redis2.8.2版本。 REDIS_SET集合数据类型与指令相关文件是t_set.h, redis.h, object.c 转载请注明,文章出自:http://blog...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:NoSQL之Redis对set(集合)数据类型的操作之二
举报原因:
原因补充:

(最多只允许输入30个字)