================四十五种(有序和无序集合):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. sql中 in 、not in 、exists、not exists 使用方法和区别

    % 的一类. NOT IN:通过 NOT IN keyword引入的子查询也返回一列零值或很多其它值. 以下查询查找没有出版过商业书籍的出版商的名称. SELECT pub_name FROM pub ...

  2. Win32 Windows编程 九

    资源的使用 1 资源文件 图标 光标 字符串 菜单  加速键 对话框资源位图等等 资源脚本文件 - 扩展名为RC文件 定义了资源和相关文件等信息 资源编译器 - RC.exe 2 图标资源 ICON ...

  3. 我收集的sonar参考资料

    sonarQube代码质量管理工具环境筹建笔记 http://www.myexception.cn/open-source/1307345.html 配置sonar.jenkins进行持续审查 htt ...

  4. IBatis增删改差的实现以及注意点

    此次进讲述对表操作的实现细节.废话不多说,代码见真章. <?xml version="1.0" encoding="utf-8" ?> <sq ...

  5. Visual Studio 2013中c#语言规范5.0

    文件位置 vs安装路径 "C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC#\Specifications\2052\CSharp ...

  6. C++ STL简化了编程

     图1.STL和c++标准模板库 作为C++标准必不可少的一部分,STL应该是渗透在C++程序的角角落落里的. STL不是实验室里的宠儿.也不是程序猿桌上的摆设.她的激动人心并不是昙花一现.本教程旨在 ...

  7. ehcache历史变迁及常用API的使用(转)

    ehcache是一个用Java实现的使用简单,高速,实现线程安全的缓存管理类库,ehcache提供了用内存,磁盘文件存储,以及分布式存储方式等多种灵活的cache管理方案.同时ehcache作为开放源 ...

  8. 但从谈论性能点SQL Server选择聚集索引键

    简单介绍 在SQL Server中,数据是按页进行存放的.而为表加上聚集索引后,SQL Server对于数据的查找就是依照聚集索引的列作为keyword进行了. 因此对于聚集索引的选择对性能的影响就变 ...

  9. 谁占用了我的Buffer Pool

    原文:谁占用了我的Buffer Pool 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/01/11/buffer-pool.aspx 我在做SQL S ...

  10. DBA查询命令积累——不断更新

    原文:DBA查询命令积累--不断更新 一.服务器配置: 1.兼容级别:兼容级别只影响指定数据库中的行为,而不会影响整个服务器上的行为. 1.1.查看数据库兼容级别及更改兼容级别: SELECT com ...