04_NoSQL数据库之Redis数据库:set类型和zset类型

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:  sets类型及操作    Set是集合,它是string类型的无序集合。set是通过hash table实现的,添加,删除和查找复杂度都是0(1)。对集合我们可以取并集、交集、差集。通过这些操作我们可以实现sns中的好友推荐和blog的tag功能。   sadd:向集合中添加一个元素,通名称为key的set中添加元素。 [tot


sets类型及操作

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

 

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

[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:删除名称为keyset中的元素,删除成功返回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:无法指定弹出元素,是随机返回并删除名称为keyset中一个元素。

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表示的意思是将myset3myset2的差集存储到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 myset2myset3myset2的差集存入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返回名称为keyset的元素个数。(看集合中的元素个数)

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是否是名称为keyset的元素。(判断某个元素是否是某个集合中的元素,是返回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:随机返回名称为keyset的一个元素,但不删除元素。

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类型及操作

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

 

zadd:向名称为keyzset中添加元素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:删除名称为keyzset中的元素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:如果在名称为keyzset中已经存在元素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:返回名称为keyzset中的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:返回名称为keyzsetmember元素的排名。(按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:返回名称为keyzset(score从大到小顺序)中的indexstartend的所有元素。(也就是说是反向排序)

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   //删除序号为25之间的元素

(integer) 2

127.0.0.1:6379> zrange sset2 0 -1 withscores

1) "one"

2) "1"

127.0.0.1:6379>

 

 

 

 

 

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
27天前
|
存储 NoSQL 关系型数据库
Redis 集合(Set)
10月更文挑战第17天
36 5
|
1月前
|
存储 监控 NoSQL
九大核心NoSQL数据库及使用场景详解
【10月更文挑战第6天】在当今大数据与云计算飞速发展的时代,NoSQL数据库以其灵活的数据模型、可扩展性和高性能,成为了众多应用场景下的首选。本文将为您详细介绍九大核心NoSQL数据库及其典型使用场景,帮助您在工作和学习中更好地选择和应用。
58 3
|
7天前
|
存储 缓存 NoSQL
常见的 NoSQL 数据库有哪些?
常见的 NoSQL 数据库有哪些?
11 2
|
12天前
|
存储 NoSQL PHP
如何用Redis高效实现点赞功能?用Set?还是Bitmap?
在众多软件应用中,点赞功能几乎成为标配。本文从实际需求出发,探讨如何利用 Redis 的 `Set` 和 `Bitmap` 数据结构设计高效点赞系统,分析其优缺点,并提供 PHP 实现示例。通过对比两种方案,帮助开发者选择最适合的存储方式。
26 3
|
20天前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
23天前
|
存储 SQL JSON
介绍一下RDBMS和NoSQL数据库之间的区别
【10月更文挑战第21天】介绍一下RDBMS和NoSQL数据库之间的区别
48 2
|
23天前
|
存储 SQL NoSQL
数据库技术深度探索:从关系型到NoSQL的演变
【10月更文挑战第21天】数据库技术深度探索:从关系型到NoSQL的演变
31 1
|
27天前
|
存储 NoSQL 关系型数据库
Redis 有序集合(sorted set)
10月更文挑战第17天
43 4
|
30天前
|
存储 NoSQL 搜索推荐
nosql
【10月更文挑战第14天】nosql
19 2
|
1月前
|
消息中间件 存储 监控
redis 的List类型 实现 排行榜
【10月更文挑战第8天】
37 2