1、Redis 集合(Set)

参考菜鸟教程:http://www.runoob.com/redis/redis-sets.html

Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

  向集合添加一个或多个成员

127.0.0.1:6379> sadd a redis
(integer) 1

  获取集合的成员数

127.0.0.1:6379> scard a
(integer) 3

  判断集合是否包含某元素,返回1表示包含

127.0.0.1:6379> sismember a redis
(integer) 1
127.0.0.1:6379> sismember a redis1
(integer) 0

  返回集合中的所有成员

127.0.0.1:6379> smembers a
1) "redis"
2) "mongodb"
3) "mysql"

2、Redis 有序集合(sorted set)

参考菜鸟教程:http://www.runoob.com/redis/redis-sorted-sets.html

Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

有序集合的成员是唯一的,但分数(score)却可以重复。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

  向有序集合添加一个或多个成员,或者更新已存在成员的分数:ZADD key score1 member1 [score2 member2]

127.0.0.1:6379> zadd a 1 redis
(integer) 1
127.0.0.1:6379> zadd a 2 mongodb
(integer) 1
127.0.0.1:6379> zadd a 3 mysql
(integer) 1
127.0.0.1:6379> zadd a 4 mysql
(integer) 0
127.0.0.1:6379> zrange a 0 10 withscores
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "4"

  获取有序集合的成员数

127.0.0.1:6379> zcard a
(integer) 3

  计算在有序集合中指定区间分数的成员数:zcount key min max

127.0.0.1:6379> zcount a 2 3
(integer) 1
127.0.0.1:6379> zcount a 2 4
(integer) 2

  有序集合中对指定成员的分数score加上增量 increment

127.0.0.1:6379> zincrby a 10 mysql //msyql元素的score增加10
"14"

  通过索引区间返回有序集合成指定区间内的成员:zrange key start stop [withscores]

127.0.0.1:6379> zrange a 0 10 withscores //索引区间
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "14"

  在有序集合中计算指定字典区间内成员数量:ZLEXCOUNT key min max

127.0.0.1:6379> zlexcount a - +
(integer) 3
127.0.0.1:6379> zlexcount a [a [f
(integer) 0

  通过字典区间返回有序集合的成员:ZRANGEBYLEX key min max [LIMIT offset count]

127.0.0.1:6379> zrangebylex a - +
1) "redis"
2) "mongodb"
3) "mysql"

  通过分数返回有序集合指定区间内的成员:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

127.0.0.1:6379> zrangebyscore a 2 14 withscores //分数区间
1) "mongodb"
2) "2"
3) "mysql"
4) "14"

  返回有序集合中指定成员的索引

127.0.0.1:6379> zrank a mysql
(integer) 2

  移除有序集合中的一个或多个成员

127.0.0.1:6379> zrem a mysql mongodb
(integer) 2

  移除有序集合中给定的字典区间的所有成员:ZREMRANGEBYLEX key min max

127.0.0.1:6379> zremrangebylex a - +
(integer) 1

  移除有序集合中给定的排名区间的所有成员:ZREMRANGEBYRANK key start stop 指定索引区间

127.0.0.1:6379> zadd a 1 redis
(integer) 1
127.0.0.1:6379> zadd a 2 mongodb
(integer) 1
127.0.0.1:6379> zadd a 3 mysql
(integer) 1
127.0.0.1:6379> zrange a 0 10 withscores
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "3"
127.0.0.1:6379> zremrangebyrank a 0 2 //索引区间
(integer) 3
127.0.0.1:6379> zrange a 0 10 withscores
(empty list or set)
127.0.0.1:6379>

  移除有序集合中给定的分数区间的所有成员

127.0.0.1:6379> zadd a 1 redis
(integer) 1
127.0.0.1:6379> zadd a 2 mongodb
(integer) 1
127.0.0.1:6379> zadd a 3 mysql
(integer) 1
127.0.0.1:6379> zremrangebyscore a 2 3 //分数区间
(integer) 2
127.0.0.1:6379> zrange a 0 10 withscores
1) "redis"
2) "1"

  返回有序集中指定区间内的成员,通过索引,分数从高到底

127.0.0.1:6379> zadd a 1 reids
(integer) 1
127.0.0.1:6379> zadd a 10 mongodb
(integer) 1
127.0.0.1:6379> zadd a 4 mysql
(integer) 1
127.0.0.1:6379> zrange a 0 2 withscores
1) "reids"
2) "1"
3) "mysql"
4) "4"
5) "mongodb"
6) "10"
127.0.0.1:6379> zrevrange a 0 2
1) "mongodb"
2) "mysql"
3) "reids"
127.0.0.1:6379> zrevrange a 0 2 withscores //索引区间
1) "mongodb"
2) "10"
3) "mysql"
4) "4"
5) "reids"
6) "1"

  返回有序集中指定分数区间内的成员,分数从高到低排序:ZREVRANGEBYSCORE key max min [WITHSCORES]

127.0.0.1:6379> zrevrangebyscore a 100 0 withscores
1) "mongodb"
2) "10"
3) "mysql"
4) "4"
5) "reids"
6) "1"

  返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序

127.0.0.1:6379> zrevrangebyscore a 100 0 withscores
1) "mongodb"
2) "10"
3) "mysql"
4) "4"
5) "reids"
6) "1"
127.0.0.1:6379> zrevrank a mongodb
(integer) 0 //排名从0开始
127.0.0.1:6379> zrevrank a mysql
(integer) 1

  返回有序集中,成员的分数值

127.0.0.1:6379> zscore a mysql
"4"

redist命令操作(三)--集合Set,有序集合ZSet的更多相关文章

  1. Redis 小白指南(二)- 基础命令和五大类型:字符串、散列、列表、集合和有序集合

    Redis 小白指南(二)- 基础命令和五大类型:字符串.散列.列表.集合和有序集合 引言 目录 基础命令 字符串类型 散列类型 列表类型 集合类型 有序集合类型 基础命令 1.获得符合规则的键名列表 ...

  2. python对redis的常用操作 下 (无序集合,有序集合)

    无序集合: 首先介绍增加,删除和获得所有元素的方法.我将会用第二部分来讨论集合的特殊操作: In [136]: x.sadd("challenge", 1,2,3,4,5,6,7, ...

  3. 第二百九十九节,python操作redis缓存-SortSet有序集合类型,可以理解为有序列表

    python操作redis缓存-SortSet有序集合类型,可以理解为有序列表 有序集合,在集合的基础上,为每元素排序:元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值, ...

  4. Redis 小白指南(二)- 聊聊五大类型:字符串、散列、列表、集合和有序集合

    Redis 小白指南(二)- 聊聊五大类型:字符串.散列.列表.集合和有序集合 引言 开篇<Redis 小白指南(一)- 简介.安装.GUI 和 C# 驱动介绍>已经介绍了 Redis 的 ...

  5. 高可用Redis(四):列表,集合与有序集合

    1.列表类型 1.1 列表数据结构 左边为key,是字符串类型 右边为value,是一个有序的队列,与python的列表结构相同 可以在Redis中对列表的value进行如下操作 从左边添加元素 从右 ...

  6. Redis操作集合,有序集合

    Set操作,Set集合就是不允许重复的列表 sadd(name,values) 1 # name对应的集合中添加元素 scard(name) 1 获取name对应的集合中元素个数 sdiff(keys ...

  7. python学习之-- redis模块操作 集合和有序集合

    redis 模块操作之 集合set和有序集合zset Set 集合操作,不允许重复的列表sadd(name,value):name对应的集合中添加元素scard(name):获取name对应的集合中元 ...

  8. redis学习(七)——五大数据类型总结:字符串、散列、列表、集合和有序集合

    目录 字符串类型(String) 散列类型(Hash) 列表类型(List) 集合类型(Set) 有序集合类型(SortedSet) 其它命令 一.字符串类型(String) 1.介绍: 字符串类型是 ...

  9. redis有序集合性能 列表、集合、有序集合

    https://www.cnblogs.com/pirlo21/p/7120935.html 1.1 列表 列表(list)类型是用来存储多个字符串,元素从左到右组成一个有序的集合.列表中的每个字符串 ...

随机推荐

  1. conn.encoders[SafeBytes] = conn.encoders[bytes] KeyError: <class 'bytes'>

    问题描述:Django连接mysql数据库,修改了setting.py文件后,启动服务器报错 错误截图如下: 解决方法: 1.pip install pymsql 2.在setting.py同目录下的 ...

  2. windows 共享文件

  3. CentOS-7.3 设置静态 ip

    1. VMnet8 必须设置固定 ip,否则会发生:虚拟机可以访问主机和外网,但是主机 windows 却访问不了虚拟机 2. 虚拟网络编辑器设置网关 IP(G): 必须与 VMnet8 的 ip 在 ...

  4. eclipse导出maven工程的可执行jar包

    一.eclipse导出maven工程的可执行jar包 建立两个maven工程 ZKServer 和ZKClient 注意:用maven进行开发管理的话,默认的打出来的jar包是不能运行的,需要在pom ...

  5. Git 爬坑路(从小白开始入门) ——(1)

    通过git管理项目之前,需要先注册一个GitHub账号,方便在远程仓库进行项目管理. Git之项目在本地仓库的管理(从小白开始): 一.push到远程项目 1.在个人的GitHub账号中,创建一个远程 ...

  6. Jquery小功能实例

    下拉框内容选中左右移动 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Sele ...

  7. LeetCode Weekly Contest 118

    要死要死,第一题竟然错误8次,心态崩了呀,自己没有考虑清楚,STL用的也不是很熟,一直犯错. 第二题也是在室友的帮助下完成的,心态崩了. 970. Powerful Integers Given tw ...

  8. js 计算两个时间戳之间相隔天数

    var start=1491789600000;//2017-4-10 10:00 var end=1494381600000;//2017-5-10 10:00 var utc=end-start; ...

  9. Haproxy官方文档翻译(第三章)全局参数(1) 附英文原文

    3.全局参数 在global这个节点里的参数是“进程范围的”并且经常是“操作系统指定”的.它们通常是一次性设置而且一旦正确设置不需要动来动去的.它们中的一些和命令行对应. global节点支持以下关键 ...

  10. Ubuntu查看crontab运行日志

    Ubuntu服务器/var/log下没有cron日志,这里记录一下如何ubuntu server如何查看crontab日志 crontab记录日志修改rsyslogsudo vim /etc/rsys ...