sets类型及操作

Set是集合,它是string类型的无序集合。set是通过hash table实现的,添加,删除和查找复杂度都是0(1)。对集合我们可以取并集、交集、差集。通过这些操作我们可以实现sns中的好友推荐和blog的tag功能。

sadd:向集合中添加一个元素,通名称为key的set中添加元素。

[toto@localhost bin]$ ./redis-cli

127.0.0.1:6379> sadd myset1 one

(integer) 1

127.0.0.1:6379> sadd myset1 two

(integer) 1

127.0.0.1:6379> sadd myset1 two     再次添加的时候添加不成功了。

(integer) 0

127.0.0.1:6379>

通过smembers查看集合中有哪些元素

127.0.0.1:6379> smembers myset1

1) "two"

2) "one"

127.0.0.1:6379>

srem:删除名称为key的set中的元素,删除成功返回1,删除失败返回0

127.0.0.1:6379> smembers myset2

1) "two"

2) "one"

3) "three"

127.0.0.1:6379> srem myset2 two

(integer) 1

127.0.0.1:6379> srem myset2 two

(integer) 0

127.0.0.1:6379> smembers myset2

1) "one"

2) "three"

127.0.0.1:6379>

spop:无法指定弹出元素,是随机返回并删除名称为key的set中一个元素。

127.0.0.1:6379> sadd myset3 one

(integer) 1

127.0.0.1:6379> sadd myset3 two

(integer) 1

127.0.0.1:6379> sadd myset3 three

(integer) 1

127.0.0.1:6379> sadd myset3 four

(integer) 1

127.0.0.1:6379> sadd myset3 five

(integer) 1

127.0.0.1:6379> smembers myset3

1) "four"

2) "three"

3) "one"

4) "two"

5) "five"

127.0.0.1:6379> spop myset3     //随机弹出的是three

"three"

127.0.0.1:6379> smembers myset3

1) "one"

2) "four"

3) "five"

4) "two"

127.0.0.1:6379> spop myset3   //随机弹出的是four

"four"

127.0.0.1:6379> smembers myset3

1) "one"

2) "five"

3) "two"

127.0.0.1:6379>

sdiff:两个集合的差集。

返回所有给定key与第一个key的差集。

127.0.0.1:6379> smembers myset3

1) "one"

2) "four"

3) "five"

4) "two"

127.0.0.1:6379> spop myset3

"four"

127.0.0.1:6379> smembers myset3

1) "one"

2) "five"

3) "two"

127.0.0.1:6379> sadd myset2 three

(integer) 1

127.0.0.1:6379> sadd myset2 four

(integer) 1

127.0.0.1:6379> sadd myset2 one

(integer) 1

127.0.0.1:6379> smembers myset2

1) "one"

2) "four"

3) "three"

127.0.0.1:6379> sdiff myset2 myset3    //去除myset2中含有与myset3元素的值。

1) "three"

2) "four"

127.0.0.1:6379>

sdiffstore:返回所有给定key与第一个key的差集,并将结果存为另一个key.

sdiffstore myset4 myset2 myset3表示的意思是将myset3和myset2的差集存储到myset4里面。

127.0.0.1:6379> sadd myset2 one

(integer) 1

127.0.0.1:6379> sadd myset2 two

(integer) 1

127.0.0.1:6379> sadd myset2 three

(integer) 1

127.0.0.1:6379> sadd myset3 one

(integer) 1

127.0.0.1:6379> sadd myset3 two

(integer) 1

127.0.0.1:6379> sadd myset3 three

(integer) 1

127.0.0.1:6379> sadd myset3 four

(integer) 1

127.0.0.1:6379> sadd myset3 five

(integer) 1

127.0.0.1:6379> sadd myset3 six

(integer) 1

127.0.0.1:6379> sdiff myset2 myset3

(empty list or set)

127.0.0.1:6379> sdiff myset3 myset2  //显示myset3中含有myset2的元素

1) "six"

2) "five"

3) "four"

127.0.0.1:6379> sdiffstore myset4 myset3 myset2将myset3和myset2的差集存入myset4中

(integer) 3

127.0.0.1:6379> smembers myset4

1) "six"

2) "five"

3) "four"

127.0.0.1:6379>

sinter:

返回所有给定key的交集

sinterstore将取出的差集存入到另外的一个集合中。

127.0.0.1:6379> sadd myset1 one

(integer) 1

127.0.0.1:6379> sadd myset1 two

(integer) 1

127.0.0.1:6379> sadd myset2 two

(integer) 1

127.0.0.1:6379> sadd myset2 three

(integer) 1

127.0.0.1:6379> sadd myset2 four

(integer) 1

127.0.0.1:6379> sadd myset2 five

(integer) 1

127.0.0.1:6379> sadd myset3 four

(integer) 1

127.0.0.1:6379> sadd myset3 five

(integer) 1

127.0.0.1:6379> sadd myset3 six

(integer) 1

127.0.0.1:6379> sadd myset3 seven

(integer) 1

127.0.0.1:6379> smembers myset1

1) "two"

2) "one"

127.0.0.1:6379> smembers myset2

1) "four"

2) "three"

3) "five"

4) "two"

127.0.0.1:6379> smembers myset3

1) "seven"

2) "four"

3) "six"

4) "five"

127.0.0.1:6379> sinter myset3 myset2

1) "four"

2) "five"

127.0.0.1:6379> sinterstore myset6 myset3 myset2

(integer) 2

127.0.0.1:6379> smembers myset6

1) "four"

2) "five"

127.0.0.1:6379>

sunion:表示插入并集。

返回所有给定key的并集。

127.0.0.1:6379> sadd myset1 one

(integer) 1

127.0.0.1:6379> sadd myset2 two

(integer) 1

127.0.0.1:6379> sadd myset1 two

(integer) 1

127.0.0.1:6379> sadd myset2 three

(integer) 1

127.0.0.1:6379> sadd myset2 four

(integer) 1

127.0.0.1:6379> sunion myset1 myset2    查看并集

1) "three"

2) "two"

3) "four"

4) "one"

127.0.0.1:6379> sunionstore myset7 myset1 myset2   将并集的结果存入myset7中

(integer) 4                   //返回值是4表示成功将4个元素插入myset7中

127.0.0.1:6379> smembers myset1

1) "two"

2) "one"

127.0.0.1:6379> smembers myset2

1) "three"

2) "two"

3) "four"

127.0.0.1:6379> smembers myset7

1) "three"

2) "two"

3) "four"

4) "one"

127.0.0.1:6379>

smove:从第一个key对应的set中移除member并添加到第二个对应的set中。(将第一个集合中的元素剪切下来放入第二个元素中)

将smove myset2 myset7 three表示:myset2中的three元素扔到myset7中

127.0.0.1:6379> smembers myset1

1) "two"

2) "one"

127.0.0.1:6379> smembers myset2

1) "three"

2) "two"

3) "four"

127.0.0.1:6379> sadd myset1 five

(integer) 1

127.0.0.1:6379> smembers myset8

(empty list or set)

127.0.0.1:6379> smove myset1 myset8 two  将myset1中的two元素移动到myset8中

(integer) 1

127.0.0.1:6379> smembers myset8

1) "two"

127.0.0.1:6379> smembers myset1

1) "five"

2) "one"

127.0.0.1:6379>

scard返回名称为key的set的元素个数。(看集合中的元素个数)

127.0.0.1:6379> smembers myset1    看myset1集合中的元素有哪些

1) "five"

2) "one"

127.0.0.1:6379> smembers myset2   看myset2集合中的元素有哪些

1) "three"

2) "two"

3) "four"

127.0.0.1:6379> smembers myset8   看myset8集合中的元素有哪些

1) "two"

127.0.0.1:6379> scard myset1    查看myset1中的元素个数

(integer) 2

127.0.0.1:6379> scard myset2    查看myset2中的元素个数

(integer) 3

127.0.0.1:6379> scard myset8

(integer) 1

127.0.0.1:6379>

sismember:测试member是否是名称为key的set的元素。(判断某个元素是否是某个集合中的元素,是返回1,不是返回0)

127.0.0.1:6379> smembers myset1

1) "five"

2) "one"

127.0.0.1:6379> sismember myset1 one    判断one是否是myset1中的元素

(integer) 1

127.0.0.1:6379> sismember myset1 two   判断two是否是myset1中的元素

(integer) 0

127.0.0.1:6379>

srandmember:随机返回名称为key的set的一个元素,但不删除元素。

127.0.0.1:6379> smembers myset1

1) "five"

2) "one"

127.0.0.1:6379> srandmember myset7

"three"

127.0.0.1:6379> srandmember myset7

"two"

127.0.0.1:6379> srandmember myset7

"four"

127.0.0.1:6379> srandmember myset7

"three"

Sorted sets类型及操作

Sortedset是set的一个升级版本,它在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序。可以理解为由两列的mysql表,一列存value,一列存顺序。操作中key理解为zset的名字。

zadd:向名称为key的zset中添加元素member,score用于排序。如果该元素存在,则更新器顺序。语法:zadd set名称 顺序 值

127.0.0.1:6379> zadd myzset 1 "one"

(integer) 1

127.0.0.1:6379> zadd myzset 2 "two"

(integer) 1

127.0.0.1:6379> zadd myzset 3 "two"

(integer) 0

这里的0 -1表示顺序号   withscores表示的意思是带上顺序号。

127.0.0.1:6379> zrange myzset 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "3"

127.0.0.1:6379>

再如:

127.0.0.1:6379> zadd sset1 1 two

(integer) 1

127.0.0.1:6379> zadd sset1 2 two

(integer) 0

127.0.0.1:6379> zadd sset1 3 two

(integer) 0

127.0.0.1:6379> zadd sset1 1 one

(integer) 1

127.0.0.1:6379> zrange sset1 0 -1

1) "one"

2) "two"

127.0.0.1:6379> zrange sset1 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "3"

127.0.0.1:6379>

zrem:删除名称为key的zset中的元素member

127.0.0.1:6379> zrange sset1 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "3"

127.0.0.1:6379> zrem sset1 two

(integer) 1

127.0.0.1:6379> zrange sset1 0 -1 withscores

1) "one"

2) "1"

127.0.0.1:6379>

zincrby:如果在名称为key的zset中已经存在元素member,则该元素的score增加increment,否则向该集合中添加该元素,其score的值为increment。

127.0.0.1:6379> zrange sset1 0 -1 withscores

1) "one"

2) "1"

127.0.0.1:6379> zincrby sset1 2 one    //将one的顺序号增加3,同样可以减2

"3"                               //表示one的顺序号变成了3

127.0.0.1:6379> zrange sset1 0 -1 withscores

1) "one"

2) "3"                             //one的序号变成了3

127.0.0.1:6379>

zrank:返回名称为key的zset中的member元素的排名。(按score从小到大排序)即下标。(返回的是索引值,和序号值是有差别的)

127.0.0.1:6379> zadd sset2 1 one

(integer) 1

127.0.0.1:6379> zadd sset2 2 two

(integer) 1

127.0.0.1:6379> zadd sset2 3 three

(integer) 1

127.0.0.1:6379> zadd sset2 4 four

(integer) 1

127.0.0.1:6379> zadd sset2 5 five

(integer) 1

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "2"

5) "three"

6) "3"

7) "four"

8) "4"

9) "five"

10) "5"

127.0.0.1:6379> zrank sset2 four

(integer) 3        //这里的3表示的是索引值而不是序号值。

127.0.0.1:6379>

zrevrank:返回名称为key的zset中member元素的排名。(按score从大到小排序)即下标。

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "2"

5) "three"

6) "3"

7) "four"

8) "4"

9) "five"

10) "5"

127.0.0.1:6379> zrevrank sset2 four   //获得four的逆向索引

(integer) 1

127.0.0.1:6379> zrevrank sset2 two   //获得two的逆向索引

(integer) 3

zrevrange:返回名称为key的zset(按score从大到小顺序)中的index从start到end的所有元素。(也就是说是反向排序)

127.0.0.1:6379> zrevrange sset2 0 -1 withscores

1) "five"

2) "5"

3) "four"

4) "4"

5) "three"

6) "3"

7) "two"

8) "2"

9) "one"

10) "1"

127.0.0.1:6379>

zrangebyscore:找到序号在指定范围内的元素

127.0.0.1:6379> zrevrange sset2 0 -1 withscores

1) "five"

2) "5"

3) "four"

4) "4"

5) "three"

6) "3"

7) "two"

8) "2"

9) "one"

10) "1"

127.0.0.1:6379> zrangebyscore sset2 2 4 withscores

1) "two"

2) "2"

3) "three"

4) "3"

5) "four"

6) "4"

127.0.0.1:6379>

zcount:返回集合中score在给定区间的数量。

127.0.0.1:6379> zrevrange sset2 0 -1 withscores

1) "five"

2) "5"

3) "four"

4) "4"

5) "three"

6) "3"

7) "two"

8) "2"

9) "one"

10) "1"

127.0.0.1:6379> zcount sset2 2 4    表示包括区间值

(integer) 3

127.0.0.1:6379> zcount sset2 4 5    表示包括区间值

(integer) 2

127.0.0.1:6379>

zcard:返回集合中的所有元素的个数

127.0.0.1:6379> zrevrange sset2 0 -1 withscores

1) "five"

2) "5"

3) "four"

4) "4"

5) "three"

6) "3"

7) "two"

8) "2"

9) "one"

10) "1"

127.0.0.1:6379> zcard sset2

(integer) 5

127.0.0.1:6379>

zremrangebyrank:删除集合中排名在给定区间的元素(按照索引来删除)。

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "2"

5) "three"

6) "3"

7) "four"

8) "4"

9) "five"

10) "5"

127.0.0.1:6379> zremrangebyrank sset2 2 3    //注意这里的2 3表示的是索引

(integer) 2

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "2"

5) "five"

6) "5"

127.0.0.1:6379>

zremrangebyscore:删除集合中score在给定区间的元素(表示的是按照顺序删除)。

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "2"

5) "five"

6) "5"

127.0.0.1:6379> zremrangebyscore sset2 3 4   //没有删除成功的时候返回0

(integer) 0

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

3) "two"

4) "2"

5) "five"

6) "5"

127.0.0.1:6379> zremrangebyscore sset2 2 5   //删除序号为2到5之间的元素

(integer) 2

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

127.0.0.1:6379>

04_NoSQL数据库之Redis数据库:set类型和zset类型相关推荐

  1. 数据库中的字段varchar类型和char类型的区别?

    数据库中的字段varchar类型和char类型的区别? 目录 数据库中的字段varchar类型和char类型的区别?

  2. (Redis_学习一)Redis关于string类型和hash类型数据操作

    Redis关于string类型和hash类型数据操作 set name xiaohongyang // get name setnx name xiaohy get name setex name 1 ...

  3. 数据库查询字段类型为double类型和float类型时遇到的坑

    对于小数型的字段,我们常用double类型和float类型,但是这两种类型使用的时候有很大差别,下面我们来看一下 在设计数据表时,突然发现原来FLOAT原来是很不靠谱的,所以在这里建议大家换成DOUB ...

  4. redis和sqlserver数据同步_SQLServer数据库之redis数据库的数据导入到SQLServer数据库中...

    本文主要向大家介绍了SQLServer数据库之redis数据库的数据导入到SQLServer数据库中,通过具体的内容向大家展现,希望对大家学习SQLServer数据库有所帮助. #!/usr/bin/ ...

  5. MySQL数据库和Redis数据库

    1.Redis 简介 1.1 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库.Redis是NOSQL,即非关系型数据库,也是缓存数据库,即将数据存储在缓存中, ...

  6. DATETIME类型和BIGINT 类型互相转换

    项目中使用BIGINT来存放时间,以下代码用来转换时间类型和BIGINT类型 SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ========= ...

  7. Java学习(4)—— 布尔类型、基本数据类型转换、基本数据类型和String类型的转换

    布尔类型 也叫Boolean类型,boolean只允许取true和false. boolean占一个字节. 适用于逻辑运算,流程控制语句. 有默认类型,是false.但是应该声明为成员变量或是静态变量 ...

  8. *floa类型和long类型那个取值范围更大?

    *floa类型和long类型那个取值范围更大? 作为基础知识.我们都知道float在内存中占用4个字节的空间,而long型占用8个字节的空间. 但float的取值范围是-3.403E38-3.403E ...

  9. 06-void类型和never类型

    void类型和never类型都是ts新增的类型,这两者的共同点是都常见用于声明函数的返回值的类型,这里我们把它们两放在一起介绍有助于大家区分. void,表示函数返回值空,即undefined. ne ...

最新文章

  1. c语言基础变量,C语言基础-第一篇-变量
  2. FAX modem和传真协议简介
  3. 《C和指针》学习备忘
  4. js中document.write()使用方法
  5. Poj 3281 Regional Chengdu Food(Dicnic)
  6. SpringBoot:Could not autowire there is more than one bean of xx type
  7. [素数拓展] 质因数的个数 [2007年清华大学计算机研究生机试真题]
  8. oracle sqlplus ed,Uedit32与SQLPlus结合使用技巧-数据库专栏,ORACLE
  9. 复合页( Compound Page )
  10. STL---二分查找、去重、全排列
  11. Atitit 解决Unhandled event loop exception错误的办法
  12. PS如何做文字扫描效果(用于较淡的扫描件)
  13. 两步教你在安卓中快速使用矢量图
  14. 星星之火-11:什么是无线资源以及无线资源管理RRM?
  15. For循环的简单实例
  16. string+DFS leetcode-17.电话号码下的字母组合
  17. JQUERY为元素添加样式的实现方法
  18. torch.prob
  19. 第 5 章 book / article
  20. python前后端脚本之家_Django使用中间件解决前后端同源策略问题

热门文章

  1. MATLAB机器学习系列-3:BP神经网络算例实现
  2. VTK:vtkTupleInterpolator 插值用法实战
  3. wxWidgets:显示和测试 wxDC 功能
  4. wxWidgets:wxRichTextFormattingDialog类用法
  5. boost::python::converter::is_object_manager相关的测试程序
  6. boost::phoenix::if_相关的测试程序
  7. boost::multi_array模块调整 multi_arrays 大小的测试
  8. boost::mpl模块实现partition相关的测试程序
  9. boost::intrusive::bucket_traits用法的测试程序
  10. boost::filesystem模块实现打印window属性的测试程序