================四十五种(有序和无序集合):sets种类(它是一个集)=============

     简介:  set它代表的集合。加入是随意添加----->无序集合

        

        set是集合,它是string类型的无序集合。

        set是通过hash table实现的,加入。删除和查找的复杂度都是0(1)。

        对集合我们能够取并集、交集、差集。

        通过这写操作我们能够实现sns中的好友推荐和blog的tag功能

    

    1:sadd

            向名称key的set中加入元素(唯一的)

            例:sadd myset1 one   ---->向集合myset1中加入元素one

                sadd myset1 two

            查看:smembers myset1

    2:srem

            删除名称为key的set中的元素

            例:sadd myset2 one

                srem myset2 one  --->删除one元素

    3:spop

            随机返回并删除名称为key的set中一的个元素

            例:spop myset3    --->随机弹出删除的元素

    4:sdiff

            返回全部给定key与第一个key的差集

                myset1=1,2  myset2=3,2    --返回1

            例:sdiff myset1 myset2    ---->谁在前面以谁为标准

    4:sdiffstore

            返回全部给定key与第一个key的差集,并将结果保存在一个新的key中

            例:sdiffstore myset4 myset2 myset3 ---->将myset2与myset3的差集弹出并保存到myset4中

    5:sinter

            返回全部给定key的交集(交集:里面同样的元素)

                       two,one three,one     --->one

            例:sinter myset2 myset3  --->之间的交集

    

    6:  sinterstore

            返回全部给定key与第一个key的交集,并将结果保存在一个新的key中

            例:sinterstore myset4 myset2 myset3 ---->将myset2与myset3的交集保存到myset4中

    7:sunion

            返回全部给定key的并集

            例:sunion myset1 myset2   --->取并集

    8:sunionstore

            返回全部给定key的并集。并保存到新的key中

            例:sunionstore myset4 myset1 myset2   --->取并集并 保存到myset4中

    9:smove

            从第一个key中相应的set中移除某个元素并加入到第二个相应的key中

            例:smove myset2 myset7 three  --->将myset2中的元素移动到myset7里面

    10:scard

            返回名称为key的set的元素个数

            例:scard myset8   ---->返回元素个数

    11:sismember

            測试某个元素是否是名称为KEY的set中的元素

            例:sismember myset2 two   --->測试two是否是myset2中的元素

    12:srandmember(无序的取)

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

            例:srandmember myset3   --->随机去除myset3的元素

    13:

    

    二介绍:  sorted sets=========》有序集合

    

            sortes set是set的一个升级版本号,它在set的基础上添加了一个顺序属性,

            这一属性在加入改动元素的时候能够指定,每次指定后。zset会自己主动又一次按新的值调整顺序。

能够理解为有两列的MySQL表,一列存value。一列存顺序。

操作中key理解为zset(有序集合的名称)的名字

    1:    zadd  ---反复插入时候会不成功,且将顺序更新

            向名称为key的zset中加入元素member,score用于排序,假设该元素存在,则更新其顺序

            例:zadd myzset1 1 one   --->  插入了one并指定顺序号

    zrange        

            取值:zrange myzset1 0 -1  -----> 取myzset1的全部元素

                  zrange myzset1 0 -1 withscores  ---->取出元素并吧顺序号输出

    2:zrem 删除有序集合中的一个元素

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

            样例:zrem zset1 two   --->删除two元素

    3:zincrby

            假设在名称为key的zset中已经存在元素member,则改元素的score

            添加increment(顺序号)否则向该集合中加入元素,其score的值为increment

            例:zincrby ssett1 2 one   ---->对顺序号减

                zincrby ssett1 -2 one  ---->对顺序号加

    4:zrank

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

            例:zrange zset2 0 -1 withscores

                zrank zset2 four   ---->返回一个元素的索引值

    5:zrevrank

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

            例:zrevrank zset2 four ---->和zrank顺序相反

    6: zrevrange

            值按降序排序(score从大到小排序)

            例:zrevrange zset2 0 -1 withscoress

    7:zrangebyscore

            返回集合中score在给定区域的元素

            例:zrangebyscore zset2 2 4 withscores  --->取下标2,3,4。且有序返回

    8:zcount

            返回集合中score在给定区域的数量

            例:zrangebyscore zset2 2 4     ----->2,3,4  ,就会返回3表示有3个元素

    9:zcrad

            返回集合元素中的个数

            zcrad zset2    ---->zset2里面全部元素的个数

    10:zremrangebyrank

            删除集合中排名在给定区间的元素(依照索引删除)

            例:zremrangebyrank zset2 1 1  ---->删除索引为 1到1的(1)。2,3(删除2和3)

    11:zremrangebyscore

            删除集合中score给定区间的元素(依照顺序号删除)

            例:zremrangebyscore zset2 2 5   --->删除顺序号为2到5

    

    ========================================END========================================

版权声明:本文博主原创文章,博客,未经同意不得转载。

四:redis的sets类型 - 相关操作(有序和无序集合)的更多相关文章

  1. 三:redis的List类型相关操作

    </pre><pre name="code" class="php" style="font-size: 14px;"&g ...

  2. 二:redis 的hash类型相关操作

    =====================二种:hash类型================== 介绍:redis -> hash是一个string类型的field和value的映射表 hash ...

  3. 一:redis 的string类型 - 相关操作

    *redisclient使用: =============一类:string的方法================ 介绍:string是redis的最简单类型,一个key相应一个value,strin ...

  4. redis数据类型:sorted sets类型及操作

    sorted sets类型及操作: sorted set是set的一个升级版本,它是在set的基础上增加了一个顺序 属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会 自动重新按新的值 ...

  5. redis sets类型及操作

    sets类型及操作set是集合,它是string类型的无序集合.通过hash table实现,添加.删除.查找的复杂度都是0(1).对集合我们可以实现取交际.差集并集.通过这些操作我们可以实现SNS中 ...

  6. openresty 学习笔记四:连接mysql和进行相关操作

    openresty 学习笔记四:连接mysql和进行相关操作 毕竟redis是作为缓存,供程序的快速读写,虽然reidis也可以做持久化保存,但还是需要一个做数据存储的数据库.比如首次查询数据在red ...

  7. redis的sets类型

    set是集合 , 它是string类型的无序集合 . set是通过hash table 实现的 , 添加.删除和查找的复杂度都是O(1) . 对集合我们可以取并集.交集.差集.通过这些操作我们可以实现 ...

  8. redis:list列表类型的操作

    1. list列表类型的操作 1.1. lpush/rpush key value [value ...] 链表的头部(左侧)或尾部(右侧)插入值 语法:lpush key value [value ...

  9. redis:string字符串类型的操作

    1. string字符串类型的操作: 1.1. set 设置单个值 语法:set key value [EX seconds] [PX milliseconds] [NX|XX] 注: EX seco ...

随机推荐

  1. RH033读书笔记(2)-Lab 3 Getting Help with Commands

    Lab 3 Getting Help with Commands Sequence 1: Using the Help Tools 1. man -f keyword whatis keyword l ...

  2. hdu 3333 树状数组+离线处理

    http://acm.hdu.edu.cn/showproblem.php?pid=3333 不错的题,想了非常久不知道怎么处理,并且答案没看懂,然后找个样例模拟下别人的代码立即懂了---以后看不懂的 ...

  3. sql server 数据库 只有mdf文件,如何附加

    直接附加就可以,SQL 会提示LOG文件找不到,可删除提示的错误行,只附加MDF文件,附加成功后,SQL会自动创建LOG文件.

  4. Python日志输出格式和时间格式

    formatter = logging.Formatter("%(asctime)s %(levelname)s %(message)s","%Y%b%d-%H:%M:% ...

  5. POJ 2405 Beavergnaw (计算几何-简单的问题)

    Beavergnaw Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6203   Accepted: 4089 Descri ...

  6. MAC 10.10 apache 服务器配置

    mac中自带了apache服务器, 如果需要在mac上使用apache服务器, 只需要配置并启动服务器即可. mac 10.10 中自带的apache版本是 2.4 mac 10.9 中自带的apac ...

  7. PDO基本操作Mysql

    来源:PHP开发学习门户 地址:http://www.phpthinking.com/archives/805 PHP中的PDO扩展为PHP訪问数据库定义了一个轻量级的.一致性的接口.它提供了一个数据 ...

  8. hibernate它5.many2one单向

    关系数据库表之间的关系: 1 正确 1 1 正确 许多 许多 正确 许多 表间关系设计 基于主键关联 基于外键关联 基于中间表 1 对 1关系实现: 基于主键关联 基于外键关联 基于中间表 1 对 多 ...

  9. 【LeetCode】【Python解读】Container with most water

    这个问题是芭芭拉在采访中遇到的,不幸的是,的复杂性O(n2)该,太失望了,难怪没有通过面试. Given n non-negative integers a1, a2, ..., an, where ...

  10. HDU 4819 Mosaic D区段树

    连接:pid=4819">http://acm.hdu.edu.cn/showproblem.php?pid=4819 意:给出一个800×800下面的矩阵.每次更新一个点的值为以这个 ...