Set操作、Set集合就是不允许重复的列表


  (无序集合)

  • sadd(name,values)
  • # name对应的集合中添加元素
  • scard(name)
  • # 获取name对应的集合中元素个数
  • sdiff(keys, *args)
  • 在第一个name对应的集合中且不在其他name对应的集合的元素集合
  • sdiffstore(dest, keys, *args)
  • # 获取第一个name对应的集合中且不在其他name对应的集合,再将其新加入到dest对应的集合中
  • sinter(keys, *args)
  • # 获取多一个name对应集合的并集
  • sinterstore(dest, keys, *args)
  • # 获取多一个name对应集合的并集,再讲其加入到dest对应的集合中
  • sismember(name, value)
  • # 检查value是否是name对应的集合的成员
  • smembers(name)
  • # 获取name对应的集合的所有成员
  • smove(src, dst, value)
  • # 将某个成员从一个集合中移动到另外一个集合
  • spop(name)
  • # 从集合的右侧(尾部)移除一个成员,并将其返回
  • srandmember(name, numbers)
  • # 从name对应的集合中随机获取 numbers 个元素
  • srem(name, values)
  • # 在name对应的集合中删除某些值
  • sunion(keys, *args)
  • # 获取多一个name对应的集合的并集
  • sunionstore(dest,keys, *args)
  • # 获取多一个name对应的集合的并集,并将结果保存到dest对应的集合中
  • sscan(name, cursor=0, match=None, count=None)
  • sscan_iter(name, match=None, count=None)
  • # 同字符串的操作,用于增量迭代分批获取元素,避免内存消耗太大

  (有序集合)

  在集合的基础上,为每元素排序;元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值,即:值和分数,分数专门用来做排序。

  • zadd(name, *args, **kwargs)
  • # 在name对应的有序集合中添加元素
  • # 如:
    # zadd('zz', 'n1', , 'n2', )
    # 或
    # zadd('zz', n1=, n2=)
  • zcard(name)
  • # 获取name对应的有序集合元素的数量
  • zcount(name, min, max)
  • # 获取name对应的有序集合中分数 在 [min,max] 之间的个数
  • zincrby(name, value, amount)
  • # 自增name对应的有序集合的 name 对应的分数
  • r.zrange( name, start, end, desc=False, withscores=False, score_cast_func=float)
  • # 按照索引范围获取name对应的有序集合的元素
  • # 参数:
    # name,redis的name
    # start,有序集合索引起始位置(非分数)
    # end,有序集合索引结束位置(非分数)
    # desc,排序规则,默认按照分数从小到大排序
    # withscores,是否获取元素的分数,默认只获取元素的值
    # score_cast_func,对分数进行数据转换的函数 # 更多:
    # 从大到小排序
    # zrevrange(name, start, end, withscores=False, score_cast_func=float) # 按照分数范围获取name对应的有序集合的元素
    # zrangebyscore(name, min, max, start=None, num=None, withscores=False, score_cast_func=float)
    # 从大到小排序
    # zrevrangebyscore(name, max, min, start=None, num=None, withscores=False, score_cast_func=float)
  • zrank(name, value)
  • # 获取某个值在 name对应的有序集合中的排行(从 0 开始)
  • # 更多:
    # zrevrank(name, value),从大到小排序
  • zrem(name, values)
  • # 删除name对应的有序集合中值是values的成员
  • # 如:zrem('zz', ['s1', 's2'])
  • zremrangebyrank(name, min, max)
  • # 根据排行范围删除
  • zremrangebyscore(name, min, max)
  • # 根据分数范围删除
  • zscore(name, value)
  • # 获取name对应有序集合中 value 对应的分数
  • zinterstore(dest, keys, aggregate=None)
  • # 获取两个有序集合的交集,如果遇到相同值不同分数,则按照aggregate进行操作
  • # aggregate的值为:  SUM  MIN  MAX
  • zunionstore(dest, keys, aggregate=None)
  • # 获取两个有序集合的并集,如果遇到相同值不同分数,则按照aggregate进行操作
  • # aggregate的值为:  SUM  MIN  MAX
  • zscan(name, cursor=0, match=None, count=None, score_cast_func=float)
  • zscan_iter(name, match=None, count=None,score_cast_func=float)
  • # 同字符串相似,相较于字符串新增score_cast_func,用来对分数进行操作

Redis set集合的更多相关文章

  1. Redis 有序集合(sorted set)

    Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员进行从小到大的排序. 有序 ...

  2. redis 有序集合(zset)函数

    redis 有序集合(zset)函数 zAdd 命令/方法/函数 Adds the specified member with a given score to the sorted set stor ...

  3. redis学习-集合set常用命令

    redis学习-集合set常用命令   1.sadd:添加一个元素到集合中(集合中的元素无序的并且唯一) 2.smembers:查看集合中所有的元素(上图事例) 3.srem:删除结合中指定的元素 4 ...

  4. Redis有序集合

    Redis有序集合类似Redis集合存储在设定值唯一性.不同的是,一个有序集合的每个成员带有分数,用于以便采取有序set命令,从最小的到最大的分数有关. Redis 有序set添加,删除和测试中的O( ...

  5. Redis 操作集合数据

    Redis 操作集合数据: > sadd set1 Tom // sadd 用于往集合中添加元素 (integer) > sadd set1 John (integer) > sad ...

  6. Redis 有序集合(sorted set),发布订阅,事务,脚本,连接,服务器(三)

    Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是通过 ...

  7. redis有序集合的使用

    Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是通过 ...

  8. redis有序集合数据类型---sortedset

    一.概述 redis有序集合和集合一样,也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数. redis正式通过分数来为集合中的重圆进行从小到大的 ...

  9. 数据结构与算法简记--redis有序集合实现-跳跃表

    跳表 定义 为一个值有序的链表建立多级索引,比如每2个节点提取一个节点到上一级,我们把抽出来的那一级叫做索引或索引层.如下图所示,其中down表示down指针,指向下一级节点.以此类推,对于节点数为n ...

  10. 基于redis有序集合,实现简单的延时任务

    基于redis有序集合,实现简单的延时任务 延时任务的场景很多,开发过程中我们经常会遇到,比如说: 1.订单未付款,5分钟后自动取消,这是电商网站非常普遍的需求: 2.用户创建订单不付款,3分钟后自动 ...

随机推荐

  1. 用户和登录的ID、Name和SID

    SQL Server的安全主体主要分为Login.User和Role,不仅有ID属性,还有Name属性和SID属性,SID是指Security ID.在查看用户和登录的时候,受到模拟上下文的影响.当执 ...

  2. Spring5源码解析2-register方法注册配置类

    接上回已经讲完了this()方法,现在来看register(annotatedClasses);方法. // new AnnotationConfigApplicationContext(AppCon ...

  3. SpringBoot2使用Jetty容器(替换默认Tomcat)

    https://blog.csdn.net/hanchao5272/article/details/99649252   Jetty和tomcat的比较 Tomcat和Jetty都是一种Servlet ...

  4. 配置文件_自定义section标签获取数据

    前言:为了节约时间,先只粘贴关键代码: 1-添加section标签,name为自定义标签名称,type为:命名空间+类型,程序集名称 <section name="watchModel ...

  5. RandomAccessFile实现简易记事本工具操作

    package seday03; import java.io.IOException; import java.io.RandomAccessFile; import java.util.Scann ...

  6. 判断map是否包含另一个map

    判断map是否包含另一个map: map不同与list集合,list集合有直接判断集合是否包含其他集合或者元素的方法. boolean contains(Object o) 如果list包含指定的元素 ...

  7. Linux根目录下各目录含义

    /boot:系统启动的相关文件,比如内核,grub /etc:配置文件 /dev:设备文件 /root:root用户的家目录 /home:用户家目录 /lib:库文件 /bin:用户的命令文件 /sb ...

  8. [MySQL] 解决Error 1698: Access denied for user 'root'@'localhost'

    当程序中使用root账号连接mysql时报以下错误,但是使用命令行是可以正常连接的,那么就查询下mysql数据库的user表,查看下当前用户的密码加密方式,看看是不是unix_socketMariaD ...

  9. CodeForces - 1228C(质因数分解+贡献法)

    题意 https://vjudge.net/problem/CodeForces-1228C 首先先介绍一些涉及到的定义: 定义prime(x)表示x的质因子集合.举例来说,prime(140)={2 ...

  10. webstorm的git操作使用

    0. 前言 在上一篇文章中,讲述了使用webstorm去调试node程序,最近研究了一下如何使用webstorm去操作git. 对于git的使用,大家的使用方式均有不同,最王道的方式非命令行莫属,基于 ...