NoSQL之Redis对set(集合)数据类型的操作之二
2013-12-03 13:51
821 查看
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或者微博的一些动态信息,实时消息或者实时推荐和分析都会非常方便。
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对set(集合)数据类型的操作之一
- NoSQL之Redis对zset(有序集合)数据类型的操作
- Redis和nosql简介,api调用;Redis数据功能(String类型的数据处理);List数据结构(及Java调用处理);Hash数据结构;Set数据结构功能;sortedSet(有序集合)数
- Redis和nosql简介,api调用;Redis数据功能(String类型的数据处理);List数据结构(及Java调用处理);Hash数据结构;Set数据结构功能;sortedSet(有序集合)数
- Redis数据类型--SortedSet(有序集合)
- Redis无序集合数据类型操作命令
- Redis数据类型操作(五) —— Sorted Set
- Redis----sorted set数据类型操作
- Redis笔记7:数据类型之有序集合(sorted set)
- Redis有序集合数据类型操作命令
- redis 的使用 ( set集合类型操作)
- 【Redis缓存机制】6.Set集合类型操作使用
- redis:set数据类型和操作
- NoSQL之Redis对string数据类型的操作
- Redis数据类型--Set(集合)
- Redis数据类型操作(四) —— Set
- Redis的数据类型及操作(三):set类型
- redis 的使用 (sort set排序集合类型操作)
- redis----set 类型数据操作指令简介
- C++ STL 有关于SET集合的基本操作,本文不包含涉及到自定义数据类型的排序