================四十五种(有序和无序集合):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. Apache与Tomcat整合(转)

    一 Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache只是作为一个转发,对jsp的处理是由 ...

  2. linux下&quot;=&quot;号与&quot;==&quot;号

    <鸟哥的linux私房菜>基础学习篇P382中说,在bash中"="与"=="是同样的,都代表推断是否相等,仅仅只是因为其它语言一般写法使用&quo ...

  3. 在borland c++ builder 中使用 google test (gtest)

    google test version: 1.6 c++ builder version: xe6 1 download google test 1.6 2 unzip the zip file. T ...

  4. 希尔排序----java实现

    思路:希尔排序是分组基础上的直接插入排序,给定的一个步长数组,每个小组先直接插入排序.虽然有四次循环,但是每次循环次数少. package com.sheepmu.text; import java. ...

  5. cookie在vs又一次run的时候丢失

    今天写个关于http cookie的demo,发现仅仅要vs又一次执行后cookie的值就会丢失,代码例如以下 protected void Page_Load(object sender, Even ...

  6. POJ 2352 Stars 树阵

    标题效果:特定y值在升序一些点.一个点的定义level值点的数目对于其左下,每个请求level多少分. 思维:因为y值它是按升序.所以分的差距仅仅是推断x值相比之前的大.就用树状数组维护. CODE: ...

  7. IOS使用Jenkins持续集成

    本文详细介绍了开发过程,提高效率进行IOS-Jenkins持续集成. 第二http://blog.csdn.net/monkey_cool/article/details/43270885 背景 平时 ...

  8. C本学习笔记scanf

    一个.scanf功能介绍             这也是在stdio.h中声明的一个函数.因此使用前必须增加#include<stdio.h>. 调用scanf函数时,须要传入变量的地址作 ...

  9. 好的安排小明(南阳19)(DFS)

    擅长排列的小明 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描写叙述 小明十分聪明,并且十分擅长排列计算.比方给小明一个数字5,他能立马给出1-5按字典序的全排列,假设你想 ...

  10. LeetCode219:Contains Duplicate II

    Given an array of integers and an integer k, find out whether there there are two distinct indices i ...