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
删除表中指定位置区间的元素
(转载请注明花儿为何那样红博客)