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. lock 单例模式

    单例模式只允许创建一个对象,因此节省内存,加快对象访问速度,因此对象需要被公用的场合适合使用,如多个模块使用同一个数据源连接对象等等 网站的计数器,一般也是采用单例模式实现,否则难以同步 单例模式要素 ...

  2. Oracle函数中对于NO_DATA_FOUND异常处理的研究

    一直以来有一个困惑,一直没解决,昨天一哥们问我这个问题,决心弄清楚,终于得到了答案.先看下面这个函数: create or replace function fn_test(c_xm varchar) ...

  3. Git 命令及git服务器

    Linux 服务器上安装git yum -y install git git config  --global user.name "name" git config  --glo ...

  4. MacBook Pro App Store无法下载和更新软件解决方案

    环境:MacBook Pro 2017 系统:MacOS 10.14 问题:在App Store中无法下载和更新软件,输入App Store密码后,弹出如下对话框 咨询苹果官方技术支持电话:400-6 ...

  5. RSA 汇总

    最近工作中遇到了RSA,这个,以前只是粗略的看了一下,结果,实际使用的时候,各种眼花缭乱啊.现在整理一下RSA有哪些相关知识. 1. RSA算法本身.算法本身的内容实际上是在pkcs#1的标准里面说明 ...

  6. python学习笔记之线程、进程和协程(第八天)

    参考文档: 金角大王博客:http://www.cnblogs.com/alex3714/articles/5230609.html 银角大王博客:http://www.cnblogs.com/wup ...

  7. echart的x换行

    option = { legend: { y: 'bottom', data:['该业务正常类比例','该业务关注类比例','该业务不良类比例'] }, xAxis: { type: 'categor ...

  8. RPC REST 比较

    REST 和 RPC是两种架构设计风格. 一般情况下REST多用于与外部接口访问时的设计,RPC多用于系统内部的. 为什么这样呢? 1.RPC必然有依赖,REST必然没有,不要抬杠,SDK暂时不算. ...

  9. restful 跨域

    同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能. 就浏览器而言的, http://127.0.0.1:8000  协议 域名 端口 跨域 问题// 简单 ...

  10. 利用multiprocessing.managers开发跨进程生产者消费者模型

    研究了下multiprocessing.managers,略有收获,随笔一篇: 核心思路是构造一个manager进程,这个进程可以通过unix socket或tcp socket与其它进程通信:因为利 ...