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
刪除表中指定位置區間的元素