php笔记之-laravel-Redis set集合

set 集合操作

sadd增加set集合元素, 返回true, 重复返回false

$redis->sadd('set1', 'ab');
$redis->sadd('set1', 'cd');
$redis->sadd('set1', 'ef');

srem 移除指定元素

$redis->srem('set1', 'cd'); // 删除'cd'元素

spop 弹出首元素

$redis->spop('set1'); // 返回 'ab'

smove 移动当前set集合的指定元素到另一个set集合

$redis->sadd('set2', '123');
$redis->smove('set1', 'set2', 'ab'); // 移动'set1'中的'ab'到'set2', 返回true or false;此时 'set1'集合不存在 'ab' 这个值

scard 返回当前set表元素个数

$redis->scard('set2'); // 返回 2

sismember 判断元素是否属于当前set集合

$redis->sismember('set2', '123'); // 返回 true or false

smembers 返回当前set集合的所有元素

$redis->smembers('set2'); // 返回 array('123','ab')

sinter/sunion/sdiff 返回两个表中元素的交集/并集/补集

$redis->sadd('set1', 'ab') ;
$redis->sinter('set2', 'set1') ;  //返回array('ab')

sinterstore/sunionstore/sdiffstore 将两个表交集/并集/补集元素 copy 到第三个表中

$redis->set('foo', 0);
$redis->sinterstore('foo', 'set1');  // 等同于将'set1'的内容copy到'foo'中,并将'foo'转为set表
$redis->sinterstore('foo', array('set1', 'set2'));  // 将'set1'和'set2'中相同的元素 copy 到'foo'表中, 覆盖'foo'原有内容

srandmember 返回表中一个随机元素

$redis->srandmember('set1') ;

有序set表操作

sadd 增加元素,并设置序号,成功返回true,重复返回false

$redis->zadd('zset1', 1, 'ab');
$redis->zadd('zset1', 2, 'cd');
$redis->zadd('zset1', 3, 'ef');

zincrby 对指定元素索引值的增减,改变元素排列次序

$redis -> zincrby ( 'zset1' , 10 , 'ab' ) ; //返回11

zrem 移除指定元素

$redis->zrem('zset1', 'ef'); // 返回 true or false

zrange 按位置次序返回表中指定区间的元素

$redis->zrange('zset1', 0, 1);  // 返回位置 0 和 1 之间(两个)的元素
$redis->zrange('zset1', 0, -1); // 返回位置 0 和倒数第一个元素之间的元素(相当于所有元素)

zrevrange 同上,返回表中指定区间的元素,按次序倒排

$redis->zrevrange('zset1', 0, -1); // 元素顺序和zrange相反

zrangebyscore/zrevrangebyscore 按顺序/降序返回表中指定索引区间的元素

$redis->zadd('zset1', 3, 'ef');
$redis->zadd('zset1', 5, 'gh');
$redis->zrangebyscore('zset1', 2, 9);  //返回索引值2-9之间的元素 array('ef','gh')
$redis->zrangebyscore('zset1', 2, 9, 'withscores'); // 返回索引值2-9之间的元素并包含索引值 array(array('ef',3),array('gh',5))
//返回索引值2-9之间的元素,'withscores' =>true表示包含索引值; 'limit'=>array(1, 2),表示偏移1条,返回2条,结果为array(array('ef',3),array('gh',5))
$redis->zrangebyscore('zset1', 2, 9, array('withscores'=>true, 'limit'=>array(1, 2)));

zunionstore/zinterstore 将多个表的并集/交集存入另一个表中

$redis->zunionstore('zset3', array('zset1', 'zset2', 'zset0'));  //将'zset1','zset2','zset0'的并集存入'zset3'
$redis->zunionstore('zset3', array('zset1', 'zset2'), array('weights' => array(2, 1))); //weights参数表示权重,其中表示并集后 zset1集合的分 * 2 后存储到 zset3 集合, zset2集合的分 * 1 后存储到 zset3 集合
$redis->zunionstore('zset3', array('zset1', 'zset2'), array('aggregate' => 'max')); //'aggregate' => 'max'或'min'表示并集后相同的元素是取大值或是取小值

zcount 统计一个索引区间的元素个数

$redis->zcount('zset1', 3, 5); // 返回 2
$redis->zcount('zset1', '(3', 5));  //'(3'表示索引值在3-5之间但不含3,同理也可以使用'(5'表示上限为5但不含5

zcard 统计元素个数

$redis->zcard('zset1'); // 返回 4

zscore 查询元素的索引

$redis->zscore('zset1', 'ef'); // 返回 3

zremrangebyscore 删除一个索引区间的元素

$redis->zremrangebyscore('zset1', 0, 2); // 删除索引在0-2之间的元素('ab','cd'), 返回删除元素个数2

zrank/zrevrank 返回元素所在表顺序/降序的位置(不是索引)

$redis->zrank('zset1', 'ef'); // 返回0,因为它是第一个元素;zrevrank则返回1(最后一个)

zremrangebyrank 删除表中指定位置区间的元素

 
$redis->zremrangebyrank('zset1', 0, 10); //删除位置为0-10的元素,返回删除的元素个数2

  

posted @ 2017-09-20 17:53  花儿为何那样红  阅读(4612)  评论(0编辑  收藏  举报