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

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM