Set类型介绍

Set是string类型元素的集合。集合成员是唯一的,不能出现重复的数据;集合是通过哈希表实现的,最大的成员数达到2^32-1个

Set原生命令

命令

命令描述

实例

SADD key member1 [member2]

向集合key添加一个或多个成员,已经存在的成员将被忽略;如果key不存在,则会创建集合key然后执行插入操作;key不是集合Set类型,则返回一个错误,成功则返回被添加到集合中的新元素的数量,被忽略的成员不算

SADD set1 ‘zhu’,‘yu’,返回:2

SPOP key [count]

移除集合key中的一个或多个随机成员,并返回被移除的成员;集合不存在或者为空的时候返回nil;count参数只有在3.2+版本以上才能使用

SPOP set1,返回:‘yu’

SCARD key

返回集合中成员的个数,key不存在时返回0

SCARD set1, 返回:4

SMEMBERS key

返回集合中所有的成员。不存在的集合被视为空集合

SMEMBERS set1;返回:“lin” “qing” “yu” “shan”

SMOVE source destination member

将指定成员member从source集合移动到destination集合中,SMOVE是原子操作,要么移动成功,要么移动失败;如果source集合不存在或者source集合中不存在member成员,则SMOVE不做任何操作,返回0;否则将member成员从source移除,添加到destination中去,并返回1;如果destination中存在member,SMOVE则将source中的member删除掉;如果source或destination不是集合,则返回一个错误。如果destination不存在,则创建一个destination并写入member值

SMOVE set1 set2 ‘qing’;则set2中存在值‘qing’,而set1中被删除

SREM key member1 [member2]

移除集合key中一个或者多个成员元素,如果member不存在,则忽略此成员元素;如果key不是集合类型,则返回一个错误;成功则返回被移除元素的个数,不包括被忽略的成员元素

SREM set2 ‘qing’;返回:1

SRANDMEMBER key [count]

返回集合key中的一个或者count个成员元素,但是不删除key中相应的成员元素;如果count大于0且小于集合的大小,则返回count个成员元素组成的数组;如果count大于0且大于集合的大小,则返回整个集合;如果count小于0,则返回一个具有重复值的数组,长度为count的绝对值;count参数存在,如果集合为空,则返回一个空数组;count参数不存在,如果集合为空则返回nil。

SRANDMEMBER set1 2;返回:‘yu’ ‘lin’

SISMEMBER key member

判断成员元素member是否存在于集合key中,若存在则返回1,不存在或者key不存在返回0;

SISMEMBER set1 ‘yu’,返回1

SDIFF key1 [key2]

返回给定所有集合的差集,不存在的key视为空集。差集的结果来自于first_key,而不是其他的key,也不是所有的key的差集;返回值的类型是列表

set1(‘yu’ ‘lin’ ‘shan’),set2(‘lin’,‘ops’),SDIFF set1 set2,返回‘yu’ ‘shan’

SDIFFSTORE destination key1 [key2]

返回所有集合的差集并存到集合destination中,如果destination已经存在,则会被覆盖

SDIFFSTORE set3 set1 set2,则set3的成员包括‘yu’ ‘shan’

SINTER key1 [key2]

返回给定的所有集合的交集。不存在的集合视为空集,当给定集合中存在空集则结果集也为空集;成功则返回交集成员列表

SINTER set1 set2,返回:‘lin’

SINTERSTORE destination key1 [key2]

返回给定集合的交集并存储到集合destination中,如果destination已经存在则将其覆盖;成功则返回交集的个数

SINTERSTORE set3 set1 set2;返回:1

SUNION key1 [key2]

返回所有给定集合的并集,不存在的集合视为空集

SUNION set1 set2,返回:“lin” “ops” “yu” “shan”

SUNIONSTORE destination key1 [key2]

将给定集合的并集写入到指定的集合destination中,如果destination已经存在,则将其覆盖;成功则返回并集的个数

SUNIONSTORE set3 set1 set2,返回:4

SSCAN key cursor [MATCH pattern] [COUNT count]

用于迭代集合中键的元素,返回数组列表

SSCAN set1 0 match *n,返回数组0=>[‘lin’ ‘shan’]

php操作redis Set的函数

  • sAdd(key,value1,value2 …)函数
    * 说明:将一个或多个value成员加入到集合key中,若key不存在,则新建集合key;
    * 参数:key(集合名称),value(将要插入集合key的成员)
    * 返回值:成功则返回插入到key中的成员个数,失败则返回false
    * php $ret = $redis->sAdd($key1,'zhu','yu'); var_dump($ret); /* 2 */
  • sPop(key,[count])函数
    * 说明:随机弹出集合key中的一个或者count个成员
    * 参数:key(集合名称),count(可选项,要弹出成员的个数)
    * 返回:count不存在,随机返回key中的一个成员;count存在,返回一个包含多个key成员的数组,count>key的长度,则返回整个集合组成的数组;若key不是Set类型,则返回false
    * 注意: redis的版本>=3.2才能使用count参数
    * php $redis->sAdd($key1,'lin','qing'); $ret = $redis->sPop($key1); var_dump($ret); /* ‘zhu’ */
  • sCard(key), sSize(key)函数
    * 说明:获取集合key中成员的个数,两个函数作用是相同的
    * 参数:key(集合名称)
    * 返回:成功则返回集合的长度,集合不存在则返回false
    * php $ret = $redis->sCard($key1); var_dump($ret); /* 4 */
  • sMembers(key), sGetMembers(key)函数
    * 说明:获取集合key中所有的成员,两个函数作用是相同的
    * 参数:key(集合名称)
    * 返回:成功则返回包含key所有成员的数组,数组是随机的,集合key为空,则返回一个空数组
    * php $ret = $redis->sMembers($key1); var_dump($ret); /* array(4) { [0]=> string(4) "qing" [1]=> string(3) "lin" [2]=> string(2) "yu" [3]=> string(3) "zhu" } */ $res = $redis->sMembers($key2); var_dump($res); /* array(0) { } */
  • sMove(srcKey,dstKey,member)函数
    * 说明:从srcKey中移除member,然后写入到dstKey中,此操作是原子操作,要么成功,要么失败;
    * 参数:srcKey,dstKey(集合名称),member(将要操作的成员)
    * 返回:执行成功返回true,失败则返回false(srcKey,dstKey,member不存在)
    * php $ret = $redis->sMove($key1,$key2,'yu'); var_dump($ret); /* bool(true) */ $redis->sMembers($key2); /* ‘yu’ */
  • sRem(key,member1,[member2],…), sRemove(key,member,[member2],…)函数
    * 说明:移除集合key中的成员member,两个函数作用是相同的
    * 参数: key(集合的名称),member(集合key中的成员)
    * 返回:返回从key中移除的成员的个数
    * php $ret = $redis->sRem($key1,'lin'); var_dump($ret); /* int(1) */
  • sRandMember(key,[count])函数
    * 说明:从集合key中随机取出一个或count个成员,但是不移除key中的成员
    * 参数:key(集合的名称),count(可选项,随机取出成员的个数)
    * 返回值:没有count参数,返回key中的一个成员(string);存在count,则返回随机取出的成员组成的数组(array):count>0且大于或等于集合key的大小,则返回整个集合;count>0且小于key的大小,则返回key中的count个成员,且不重复;count<0且绝对值小于key的大小,则返回|count|个不含重复值的数组;count<0且绝对值大于key的大小,则返回|count|个含有重复值的数组;key为空集,则返回一个空数组;key不是集合类型,则返回false;
    * php $redis->sRandMember($key1,2); /* array(2) { [0]=> string(4) "qing" [1]=> string(3) "zhu" } */ $redis->sRandMember($key1,-3); /* array(3) { [0]=> string(4) "qing" [1]=> string(3) "zhu" [2]=> string(4) "qing" } */ $redis->sRandMember($key4,-3); /* array(0) { } */ $redis->sRandMember('string1',6); /* bool(false) */
  • sIsMember(key,member),sContains(key,member)函数
    * 说明: 判断member是否存在于集合key中,两个函数的作用是一样的
    * 参数: key(集合的名称),member(需要判断的值)
    * 返回:如果member存在于集合key中,则返回true,否则返回false
    * php $redis->sIsMember($key1,'qing'); /* true */
  • sDiff(key1,key2,…keyN)函数
    * 说明:获取多个key之间的差集并返回
    * 参数:keyN(集合的名称)
    * 返回:与key1相比较得到的差集所组成的数组
    * php $redis->sDiff($key1,$key2); /* array(2) { [0]=> string(4) "qing" [1]=> string(3) "zhu" } */
  • sDiffStore(dstKey,key1,key2, … keyN)函数
    * 说明:获取多个给定的集合key之间的差集并存储到集合dstKey中;如果dstKey已经存在则将其覆盖
    * 参数:dstKey(获取差集之后要存储的集合),keyN(给定的集合key)
    * 返回:执行成功则返回差集的个数;失败则返回false
    * php $redis->sDiffStore($key3,$key1,$key2); /* 2 */
  • sInter(key1,key2,…keyN)函数
    * 说明:返回所有给定的集合key的交集所组成的数组
    * 参数:keyN(集合名称)
    * 返回:返回所有给定的集合key的交集所组成的数组,如果给定的集合中存在空集,则返回一个空数组
    * php $redis->sInter($key1,$key2); /* array(0) { } */
  • sInterStore(dstKey,key1,…,keyN)函数
    * 说明:获取所有给定的集合key的交集并存入集合dstKey中;如果dstKey已经存在,则将其覆盖。
    * 参数:dstKey(目标集合的名称),keyN(给定的集合key)
    * 返回:获取所有给定的集合key的交集并存入集合dstKey中,成功则将交集写入到dstKey中并返回交集的个数,失败则返回false;
    * php $redis->sInterStore($key3,$key1,$key2);/* int(0) */
  • sUnion(key1,…,keyN)函数
    * 说明:返回给定的多个key的交集
    * 参数:keyN(集合名称)
    * 返回:成功则返回所有集合的交集所组成的索引数组,失败则返回false
    * php $redis->sUnion($key1,$key2);/* array(3) { [0]=> string(4) "qing" [1]=> string(2) "yu" [2]=> string(3) "zhu" } */
  • sUnionStore(dstkey,key1,…,keyN)函数
    * 说明: 将给定集合的并集写入到指定的集合dstKey中;如果dstKey已经存在,则将其覆盖。
    * 参数:dstkey(指定的集合),keyN(给定的集合)
    * 返回:成功则返回dstKey中集合的个数,失败则返回false
    * php $redis->sUnionStore($key3,$key1,$key2); /* int(3) */
  • sScan(key,iterator,pattern,count)函数
    * 说明:扫描(遍历)一遍集合的成员
    * 参数:key(集合的名称),iterator(迭代器),pattern(遍历时的匹配条件),count(期望返回成员的数量)
    * 返回:执行成功返回一个数组,失败则返回false