设为首页 收藏本站
查看: 1276|回复: 0

[经验分享] redis 在 php 中的应用(Set篇)

[复制链接]

尚未签到

发表于 2017-12-21 15:06:43 | 显示全部楼层 |阅读模式
  上一篇:redis 在 php 中的应用(List篇)
  本文为我阅读了redis参考手册 之后编写,注意 php_redis 和 redis-cli 的区别(主要是返回值类型和参数用法)
  Redis的 Set 是 string 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
  目录:

Set(集合)
SADD
SREM
SMEMBERS
SCARD
SMOVE
SPOP
SRANDMEMBER
SINTER
SINTERSTORE
SUNION0
SUNIONSTORE
SDIFF
SDIFFSTORE
SISMEMBER  Set(集合)
  1、SADD
  Redis Sadd 命令将一个或多个成员元素加入到集合中
  (1)已经存在于集合的成员元素将被忽略。
  (2)假如集合 key 不存在,则创建一个只包含添加的元素作成员的集合。
  (3)当集合 key 不是集合类型时,返回一个错误。
  注意:在Redis2.4版本以前, SADD 只接受单个成员值。
  语法:
  redis 127.0.0.1:6379> SADD KEY_NAME VALUE1..VALUEN
  返回值: 被添加到集合中的新元素的数量,不包括被忽略的元素。
  可用版本:>= 1.0.0
  时间复杂度:(N),N是被添加的元素的数量。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','hello');    // 已存在的 key 被忽略  

  
($redis -> sMembers('myset'));
  

//array (size=2)  
//  0 => string 'hello' (length=5)
  
//  1 => string 'foo' (length=3)
  

  2、SREM
  Redis Srem 命令用于移除集合中的一个或多个成员元素,不存在的成员元素会被忽略。
  当 key 不是集合类型,返回一个错误。
  在 Redis 2.4 版本以前, SREM 只接受单个成员值。
  语法:
  redis 127.0.0.1:6379> SREM KEY MEMBER1..MEMBERN
  返回值: 被成功移除的元素的数量,不包括被忽略的元素。
  可用版本:>= 1.0.0
  时间复杂度:O(N),N为给定member元素的数量。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

($redis -> sRem('myset','hello','foo'));    // int 2  
($redis -> sMembers('myset'));
  

//array (size=3)  
//  0 => string 'world' (length=5)
  
//  1 => string 'welcome' (length=7)
  
//  2 => string 'hi' (length=2)
  

  3、SMEMBERS
  Redis Smembers 命令返回集合中的所有的成员。 不存在的集合 key 被视为空集合。
  语法:
  redis 127.0.0.1:6379> SMEMBERS KEY VALUE
  返回值: 集合中的所有成员。
  可用版本:>= 1.0.0
  时间复杂度:O(N),N为集合的基数。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

($redis -> sMembers('myset'));  

//array (size=5)  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'hi' (length=2)
  
//  3 => string 'foo' (length=3)
  
//  4 => string 'welcome' (length=7)
  

  4、SCARD
  Redis Scard 命令返回集合中元素的数量
  语法:
  redis 127.0.0.1:6379> SCARD KEY_NAME
  返回值:集合的数量。 当集合 key 不存在时,返回 0 。
  可用版本:>= 1.0.0
  时间复杂度:O(1)
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

($redis -> sCard('myset'));     // int 5  

  5、SMOVE
  Redis Smove 命令将指定成员 member 元素从 source 集合移动到 destination 集合
  (1)SMOVE 是原子性操作。
  (2)如果 source 集合不存在或不包含指定的 member 元素,则 SMOVE 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到 destination 集合中去。
  (3)当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。
  (4)当 source 或 destination 不是集合类型时,返回一个错误。
  语法:
  redis 127.0.0.1:6379> SMOVE SOURCE DESTINATION MEMBER
  返回值:如果成员元素被成功移除,返回 1 。 如果成员元素不是 source 集合的成员,并且没有任何操作对 destination 集合执行,那么返回 0 。
  可用版本:>= 1.0.0
  时间复杂度:O(1)
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

$redis -> sAdd('destinationSet','welcome');  

  

// The first case : member 包含在 source 中($redis -> sMove('myset','destinationSet','foo'));  // boolean true  
($redis -> sMembers('myset'));
  

//array (size=4)  
//  0 => string 'hello' (length=5)
  
//  1 => string 'hi' (length=2)
  
//  2 => string 'world' (length=5)
  
//  3 => string 'welcome' (length=7)
  

  
// The second case : member 不在 source 中
  
($redis -> sMove('myset','destinationSet','not_exists'));  // boolean false
  
($redis -> sMembers('myset'));
  
//array (size=4)
  
//  0 => string 'hi' (length=2)
  
//  1 => string 'world' (length=5)
  
//  2 => string 'hello' (length=5)
  
//  3 => string 'welcome' (length=7)
  

  
// The third case : destination 中已经包含 member 元素
  
($redis -> sMove('myset','destinationSet','welcome'));  // boolean true
  
($redis -> sMembers('myset'));          // 只是将 welcome 从 myset 中移除
  
//array (size=3)
  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'hi' (length=2)
  

  6、SPOP
  Redis Spop 命令用于移除并返回集合中的一个随机元素。
  语法:
  redis 127.0.0.1:6379> SPOP KEY
  返回值:被移除的随机元素。 当集合不存在或是空集时,返回 nil 。
  可用版本:>= 1.0.0
  时间复杂度:O(1)
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

// 其值会从原集合中移除  
($redis -> sPop('myset'));      // string world
  
($redis -> sMembers('myset'));
  

//array (size=4)  
//  0 => string 'hi' (length=2)
  
//  1 => string 'foo' (length=3)
  
//  2 => string 'hello' (length=5)
  
//  3 => string 'welcome' (length=7)
  

  7、SRANDMEMBER
  Redis Srandmember 命令用于返回集合中的一个随机元素
  从 Redis 2.6 版本开始, Srandmember 命令接受可选的 count 参数:


  • 如果 count 为正数,且小于集合基数,那么命令返回一个包含 count 个元素的数组,数组中的元素各不相同。如果 count 大于等于集合基数,那么返回整个集合。
  • 如果 count 为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为 count 的绝对值。
  该操作和 SPOP 相似,但 SPOP 将随机元素从集合中移除并返回,而 Srandmember 则仅仅返回随机元素,而不对集合进行任何改动
  语法:
  redis 127.0.0.1:6379> SRANDMEMBER KEY [count]
  返回值:(1)只提供集合 key 参数时,返回一个元素;
  (2) 如果提供了 count 参数, 若 0<count<集合基数,那么返回一个包含count个元素的数组,若 count>集合基数,那么返回整个集合
  (3)如果提供了 count 参数, 若 count<0,且 count的绝对值<集合基数,那么返回一个包含count个元素的数组,若 count的绝对值>集合基数,那么返回包含count个元素的数组,元素可能重复出现多次
  可用版本:>= 1.0.0
  时间复杂度:O(1)
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

// The first case : 当没有 count 参数时,返回一个随机值,其值不会从原集合中移除  
($redis -> sRandMember('myset'));      // string foo
  
($redis -> sMembers('myset'));
  

//array (size=5)  
//  0 => string 'hello' (length=5)
  
//  1 => string 'hi' (length=2)
  
//  2 => string 'foo' (length=3)
  
//  3 => string 'world' (length=5)
  
//  4 => string 'welcome' (length=7)
  

  
// The second case : 当 0 < count < 集合基数
  
($redis -> sRandMember('myset',3));   // 返回包含 count 个元素的集合
  
//array (size=3)
  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'foo' (length=3)
  

  
// The third case : 当 0 < count 且 集合基数 < count
  
($redis -> sRandMember('myset',10));        // 返回整个集合
  
//array (size=5)
  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'foo' (length=3)
  
//  3 => string 'hi' (length=2)
  
//  4 => string 'welcome' (length=7)
  

  
// The fourth case : 当 count<0 且  |count| < 集合基数
  
($redis -> sRandMember('myset',-3));       // 返回包含 count 个元素的集合
  
//array (size=3)
  
//  0 => string 'hello' (length=5)
  
//  1 => string 'welcome' (length=7)
  
//  2 => string 'world' (length=5)
  

  
// The fifth case : 当 count<0 且  |count| > 集合基数
  
($redis -> sRandMember('myset',-8));       // 返回包含 count 个元素的集合,有重复
  
//array (size=8)
  
//  0 => string 'world' (length=5)
  
//  1 => string 'welcome' (length=7)
  
//  2 => string 'world' (length=5)
  
//  3 => string 'welcome' (length=7)
  
//  4 => string 'hello' (length=5)
  
//  5 => string 'hello' (length=5)
  
//  6 => string 'world' (length=5)
  
//  7 => string 'welcome' (length=7)
  

  8、SINTER
  Redis Sinter 命令返回给定所有给定集合的交集。 不存在的集合 key 被视为空集。 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
  语法:
  redis 127.0.0.1:6379> SINTER KEY KEY1..KEYN
  返回值:交集成员的列表。
  可用版本:>= 1.0.0
  时间复杂度:O(1)
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

$redis -> sAdd('otherset','hello');  

$redis -> sAdd('otherset','world');  

$redis -> sAdd('otherset','welcome');  

  

// The first case : 集合都不为空 , 原集合不变  
($redis -> sInter('myset','otherset'));
  

//array (size=3)  
//  0 => string 'welcome' (length=7)
  
//  1 => string 'world' (length=5)
  
//  2 => string 'hello' (length=5)
  

  
// The second case : 有空集合
  
($redis -> sInter('myset','emptyset'));     // array (size=0) empty
  

  9、SINTERSTORE
  Redis Sinterstore 命令将给定集合之间的交集存储在指定的集合中。如果指定的集合已经存在,则将其覆盖。
  语法:
  redis 127.0.0.1:6379> SINTERSTORE DESTINATION_KEY KEY KEY1..KEYN
  返回值:交集成员的列表。
  可用版本:>= 1.0.0
  时间复杂度:O(N * M),N为给定集合当中基数最小的集合,M为给定集合的个数。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

$redis -> sAdd('otherset','hello');  

$redis -> sAdd('otherset','world');  

$redis -> sAdd('otherset','welcome');  

  

$redis -> sAdd('other_destinationset','hello');  

  

// The first case : 目标集合不存在  
($redis -> sInterStore('destinationset','myset','otherset'));   // int 3
  
($redis -> sMembers('destinationset'));
  

//array (size=3)  
//  0 => string 'welcome' (length=7)
  
//  1 => string 'world' (length=5)
  
//  2 => string 'hello' (length=5)
  

  
// The second case : 目标集合已存在
  
($redis -> sInterStore('other_destinationset','myset','otherset'));   
  
($redis -> sMembers('other_destinationset'));       // 覆盖
  
//array (size=3)
  
//  0 => string 'welcome' (length=7)
  
//  1 => string 'world' (length=5)
  
//  2 => string 'hello' (length=5)
  

  10、SUNION
  Redis Sunion 命令返回给定集合的并集。不存在的集合 key 被视为空集。
  语法:
  redis 127.0.0.1:6379> SUNION KEY KEY1..KEYN
  返回值:并集成员的列表。
  可用版本:>= 1.0.0
  时间复杂度:O(N),N是所有给定集合的成员数量之和
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

$redis -> sAdd('otherset','hello');  

$redis -> sAdd('otherset','world');  

$redis -> sAdd('otherset','good');  

  

// The first case : 集合都不为空 , 原集合不变  
($redis -> sUnion('myset','otherset'));
  

//array (size=6)  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'welcome' (length=7)
  
//  3 => string 'good' (length=4)
  
//  4 => string 'hi' (length=2)
  
//  5 => string 'foo' (length=3)
  

  
// The second case : 有空集合
  
($redis -> sUnion('myset','emptyset'));
  
//array (size=5)
  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'foo' (length=3)
  
//  3 => string 'hi' (length=2)
  
//  4 => string 'welcome' (length=7)
  

  11、SUNIONSTORE
  Redis Sunionstore 命令将给定集合的并集存储在指定的集合 destination 中。如果 destination 已经存在,则将其覆盖。
  语法:
  redis 127.0.0.1:6379> SUNIONSTORE DESTINATION KEY KEY1..KEYN
  返回值:结果集中的元素数量。
  可用版本:>= 1.0.0
  时间复杂度:O(N),N是所有给定集合的成员数量之和。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

$redis -> sAdd('otherset','hello');  

$redis -> sAdd('otherset','world');  

$redis -> sAdd('otherset','good');  

  

$redis -> sAdd('other_destinationset','hello');  

  

// The first case : 目标集合不存在  
($redis -> sUnionStore('destinationset','myset','otherset'));   // int 6
  
($redis -> sMembers('destinationset'));
  

//array (size=6)  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'welcome' (length=7)
  
//  3 => string 'good' (length=4)
  
//  4 => string 'hi' (length=2)
  
//  5 => string 'foo' (length=3)
  

  
// The second case : 目标集合已存在
  
($redis -> sUnionStore('other_destinationset','myset','otherset'));   // int 6
  
($redis -> sMembers('other_destinationset'));       // 覆盖
  
//array (size=6)
  
//  0 => string 'world' (length=5)
  
//  1 => string 'hello' (length=5)
  
//  2 => string 'welcome' (length=7)
  
//  3 => string 'good' (length=4)
  
//  4 => string 'hi' (length=2)
  
//  5 => string 'foo' (length=3)
  

  12、SDIFF
  Redis Sdiff 命令返回给定集合之间的差集。不存在的集合 key 将视为空集。
  语法:
  redis 127.0.0.1:6379> SDIFF FIRST_KEY OTHER_KEY1..OTHER_KEYN
  返回值:包含差集成员的列表。
  可用版本:>= 1.0.0
  时间复杂度:O(N),N是所有给定集合的成员数量之和。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

$redis -> sAdd('otherset','hello');  

$redis -> sAdd('otherset','world');  

$redis -> sAdd('otherset','good');  

  

($redis -> sDiff('myset','otherset'));  // 此处的差集指的是第一个集合的元素,不包含后面集合的元素  
//array (size=3)
  
//  0 => string 'welcome' (length=7)
  
//  1 => string 'foo' (length=3)
  
//  2 => string 'hi' (length=2)
  

  13、SDIFFSTORE
  Redis Sdiffstore 命令将给定集合之间的差集存储在指定的集合中。如果指定的集合 key 已存在,则会被覆盖。
  语法:
  redis 127.0.0.1:6379> SDIFFSTORE DESTINATION_KEY KEY1..KEYN
  返回值:结果集中的元素数量。
  可用版本:>= 1.0.0
  时间复杂度:O(N),N是所有给定集合的成员数量之和。
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

$redis -> sAdd('otherset','hello');  

$redis -> sAdd('otherset','world');  

$redis -> sAdd('otherset','good');  

  

$redis -> sAdd('other_destinationset','hello');  

  

// The first case : 目标集合不存在  
($redis -> sDiffStore('destinationset','myset','otherset'));   // int 3, 此处指的是第一个集合中的元素
  
($redis -> sMembers('destinationset'));
  

//array (size=3)  
//  0 => string 'welcome' (length=7)
  
//  1 => string 'foo' (length=3)
  
//  2 => string 'hi' (length=2)
  

  
// The second case : 目标集合已存在
  
($redis -> sDiffStore('other_destinationset','myset','otherset'));   // int 3
  
($redis -> sMembers('other_destinationset'));       // 覆盖
  
//array (size=3)
  
//  0 => string 'welcome' (length=7)
  
//  1 => string 'foo' (length=3)
  
//  2 => string 'hi' (length=2)
  

  14、SISMEMBER
  Redis Sismember 命令判断成员元素是否是集合的成员。
  语法:
  redis 127.0.0.1:6379> SISMEMBER KEY VALUE
  返回值:如果成员元素是集合的成员,返回 1 。 如果成员元素不是集合的成员,或 key 不存在,返回 0 。
  可用版本:>= 1.0.0
  时间复杂度:O(1)
  具体实例:
  

<?php  

$redis = new redis();  

$redis -> connect('127.0.0.1',6379);  

$redis -> flushAll();  

  

$redis -> sAdd('myset','hello');  

$redis -> sAdd('myset','foo');  

$redis -> sAdd('myset','world');  

$redis -> sAdd('myset','hi');  

$redis -> sAdd('myset','welcome');  

  

($redis -> sIsMember('myset','hello'));     // true  
($redis -> sIsMember('myset','good'));      // false
  

  下一篇:redis 在php中的应用(Sorted-set篇)
  如有转载,请注明出处:http://www.cnblogs.com/chrdai/p/6846352.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-426502-1-1.html 上篇帖子: 安装Redis后RedisDesktopManager无法连接 下篇帖子: Redis五大类型操作使用以及订阅发布功能
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表