php操作redis中的hash和zset類型資料的方法和代碼例子_php執行個體

來源:互聯網
上載者:User

 前面一篇部落客要是string類型,list類型和set類型,下面hash類型和zset類型

1,hset

描述:將雜湊表key中的域field的值設為value。如果key不存在,一個新的雜湊表被建立並進行HSET操作。如果域field已經存在於雜湊表中,舊值將被覆蓋。
參數:key field value
傳回值:如果field是雜湊表中的一個建立域,並且值設定成功,返回1。如果雜湊表中域field已經存在且舊值已被新值覆蓋,返回0。

2,hsetnx

描述:將雜湊表key中的域field的值設定為value,若且唯若域field不存在。若域field已經存在,該操作無效。如果key不存在,一個新雜湊表被建立並執行HSETNX命令。
參數:key field value
傳回值:設定成功,返回1。如果給定域已經存在且沒有操作被執行,返回0。

3,hget

描述:返回雜湊表key中給定域field的值。
參數:key field
傳回值:給定域的值。當給定域不存在或是給定key不存在時,返回nil。

4,hmset

描述:同時將多個field - value(域-值)對設定到雜湊表key中。此命令會覆蓋雜湊表中已存在的域。如果key不存在,一個空雜湊表被建立並執行HMSET操作。
參數:key field value [field value ...]
傳回值:如果命令執行成功,返回OK。當key不是雜湊表(hash)類型時,返回一個錯誤。

5,hmget

描述:返回雜湊表key中,一個或多個給定域的值。如果給定的域不存在於雜湊表,那麼返回一個nil值。因為不存在的key被當作一個空雜湊表來處理,所以對一個不存在的key進行HMGET操作將返回一個只帶有nil值的表。
參數:key field [field ...]
傳回值:一個包含多個給定域的關聯值的表,表值的排列順序和給定域參數的請求順序一樣。

6,hgetall

描述:返回雜湊表key中,所有的域和值。在傳回值裡,緊跟每個網域名稱(field name)之後是域的值(value),所以傳回值的長度是雜湊表大小的兩倍。
參數:key
傳回值:以列表形式返回雜湊表的域和域的值。 若key不存在,返回空列表。

7,hdel

描述:刪除雜湊表key中的一個或多個指定域,不存在的域將被忽略。
參數:key field [field ...]
傳回值:被成功移除的域的數量,不包括被忽略的域。

8,hlen

描述:返回雜湊表key中域的數量。
參數:key
傳回值:雜湊表中域的數量。當key不存在時,返回0。

9,hexists

描述:查看雜湊表key中,給定域field是否存在。
參數:key field
傳回值:如果雜湊表含有給定域,返回1。如果雜湊表不含有給定域,或key不存在,返回0。

10,hincrby

描述:為雜湊表key中的域field的值加上增量increment。增量也可以為負數,相當於對給定域進行減法操作。
參數:key field increment
傳回值:執行HINCRBY命令之後,雜湊表key中域field的值。

11,hkeys

描述:返回雜湊表key中的所有域。
參數:key
傳回值:一個包含雜湊表中所有域的表。當key不存在時,返回一個空表。

12,hvals

描述:返回雜湊表key中的所有值。
參數:key
傳回值:一個包含雜湊表中所有值的表。當key不存在時,返回一個空表。

以上12個方法的代碼例子:

複製代碼 代碼如下:

<?php 
$redis = new redis(); 
$redis->connect('192.168.1.108', 6379); 
$redis->delete('test'); 
$redis->hset('test', 'key1', 'hello'); 
echo $redis->hget('test', 'key1');     //結果:hello 
 
echo "<br>"; 
$redis->hSetNx('test', 'key1', 'world'); 
echo $redis->hget('test', 'key1');   //結果:hello 
 
$redis->delete('test'); 
$redis->hSetNx('test', 'key1', 'world'); 
echo "<br>"; 
echo $redis->hget('test', 'key1');   //結果:world 
 
echo $redis->hlen('test');   //結果:1 
var_dump($redis->hdel('test','key1'));  //結果:bool(true)  
 
$redis->delete('test'); 
$redis->hSet('test', 'a', 'x'); 
$redis->hSet('test', 'b', 'y'); 
$redis->hSet('test', 'c', 'z'); 
print_r($redis->hkeys('test'));  //結果:Array ( [0] => a [1] => b [2] => c )  
 
print_r($redis->hvals('test'));  //結果:Array ( [0] => x [1] => y [2] => z )  
 
print_r($redis->hgetall('test'));  //結果:Array ( [a] => x [b] => y [c] => z )  
 
var_dump($redis->hExists('test', 'a'));  //結果:bool(true)  
 
$redis->delete('test'); 
echo $redis->hIncrBy('test', 'a', 3);    //結果:3 
echo $redis->hIncrBy('test', 'a', 1);    //結果:4 
 
$redis->delete('test'); 
var_dump($redis->hmset('test', array('name' =>'tank', 'sex'=>"man"))); //結果:bool(true) 
print_r($redis->hmget('test', array('name', 'sex')));  //結果:Array ( [name] => tank [sex] => man ) 
?> 

13,zadd

描述:
增加一個或多個元素,如果該元素已經存在,更新它的socre值
雖然有序集合有序,但它也是集合,不能重複元素,添加重複元素只會
更新原有元素的score值
參數:
key
score : double
value: string
傳回值:1 or 0

14,zrange

描述:取得特定範圍內的排序元素,0代表第一個元素,1代表第二個以此類推。-1代表最後一個,-2代表倒數第二個...
參數:
key
start: long
end: long
withscores: bool = false
傳回值:數組

15,zdelete, zrem

描述:從有序集合中刪除指定的成員。
參數:
key
member
傳回值:1 or 0

16,zrevrange

描述:返回key對應的有序集合中指定區間的所有元素。這些元素按照score從高到低的順序進行排列。對於具有相同的score的元素而言,將會按照遞減的字典順序進行排列。該命令與ZRANGE類似,只是該命令中元素的排列順序與前者不同。
參數:
key
start: long
end: long
withscores: bool = false
傳回值:數組

17,zrangebyscore, zrevrangebyscore

描述:返回key對應的有序集合中score介於min和max之間的所有元素(包哈score等於min或者max的元素)。元素按照score從低到高的順序排列。如果元素具有相同的score,那麼會按照字典順序排列。
可選的選項LIMIT可以用來擷取一定範圍內的匹配元素。如果位移值較大,有序集合需要在獲得將要返回的元素之前進行遍曆,因此會增加O(N)的時間複雜度。可選的選項WITHSCORES可以使得在返回元素的同時返回元素的score,該選項自從Redis 2.0版本後可用。
參數:
key
start: string
end: string
options: array
傳回值:數組

18,zcount

描述:返回key對應的有序集合中介於min和max間的元素的個數。
參數:
key
start: string
end: string
傳回值:數組長度

19,zremrangebyscore, zreleterangebyscore

描述:移除key對應的有序集合中scroe位於min和max(包含端點)之間的所喲元素。從2.1.6版本後開始,區間端點min和max可以被排除在外,這和ZRANGEBYSCORE的文法一樣。
參數:
key
start: double or "+inf" or "-inf" string
end: double or "+inf" or "-inf" string
傳回值:刪除元素個數

20,zremrangebyrank, zdeleterangebyrank

描述:移除key對應的有序集合中rank值介於start和stop之間的所有元素。start和stop均是從0開始的,並且兩者均可以是負值。當索引值為負值時,表明位移值從有序集合中score值最高的元素開始。例如:-1表示具有最高score的元素,而-2表示具有次高score的元素,以此類推。
參數:
key
start: LONG
end: LONG
傳回值:刪除元素個數

21,zsize, zcard

描述:返回儲存在key對應的有序集合中的元素的個數。
參數:key
傳回值:元素個數

22,zscore

描述:返回key對應的有序集合中member的score值。如果member在有序集合中不存在,那麼將會返回null。
參數:key member

23,zrank, zrevrank

描述:返回key對應的有序集合中member元素的索引值,元素按照score從低到高進行排列。rank值(或index)是從0開始的,這意味著具有最低score值的元素的rank值為0。使用ZREVRANK可以獲得從高到低排列的元素的rank(或index)。
參數:key member
傳回值:數字

24,zincrby

將key對應的有序集合中member元素的scroe加上increment。如果指定的member不存在,那麼將會添加該元素,並且其score的初始值為increment。如果key不存在,那麼將會建立一個新的有序列表,其中包含member這一唯一的元素。如果key對應的值不是有序列表,那麼將會發生錯誤。指定的score的值應該是能夠轉換為數字值的字串,並且接收雙精確度浮點數。同時,你也可用提供一個負值,這樣將減少score的值。
參數:key value member
傳回值:字元型資料

25,zunion

描述:keys對應的numkeys個有序集合計算合集,並將結果儲存在destination中
參數:keyOutput arrayZSetKeys arrayWeights aggregateFunction
傳回值:並集數組

26,zinter

描述:keys對應的numkeys個有序集合計算交集,並將結果儲存在destination中
參數:keyOutput arrayZSetKeys arrayWeights aggregateFunction
傳回值:交集數組


13-26的代碼例子:

複製代碼 代碼如下:

$redis = new redis(); 
$redis->connect('192.168.1.108', 6379); 
$redis->delete('test'); 
$redis->zadd('test', 1, 'val1'); 
$redis->zadd('test', 0, 'val2'); 
$redis->zadd('test', 3, 'val3'); 
 
print_r($redis->zrange('test', 0, -1)); //結果:Array ( [0] => val2 [1] => val1 [2] => val3 ) 
 
$redis->zdelete('test', 'val2'); 
print_r($redis->zrange('test', 0, -1)); //結果:Array ( [0] => val1 [1] => val3 )  
 
$redis->zadd('test',4, 'val0'); 
print_r($redis->zrevrange('test', 0, -1));  //結果:Array ( [0] => val0 [1] => val3 [2] => val1 ) 
print_r($redis->zrevrange('test', 0, -1,true));  //結果:Array ( [val0] => 4 [val3] => 3 [val1] => 1 )  
 
echo "<br>"; 
$redis->zadd('key', 0, 'val0'); 
$redis->zadd('key', 2, 'val2'); 
$redis->zadd('key', 10, 'val10'); 
 
print_r($redis->zrangebyscore('key', 0, 3, array('limit' => array(1, 1),'withscores' => TRUE))); //結果:Array ( [val2] => 2 ) 
print_r($redis->zrangebyscore('key', 0, 3, array('limit' => array(1, 1)))); //結果:Array ( [0] => val2 )  
 
echo $redis->zcount('key', 0, 3); //結果:2 
 
$redis->zremrangebyscore('key', 0, 3); 
print_r($redis->zrange('key', 0, -1));  //結果:Array ( [0] => val10 )  
 
echo $redis->zsize('key');   //結果:1 
 
$redis->zadd('key', 2.5, 'aaaa'); 
echo $redis->zscore('key', 'aaaa');   //結果:2.5 
 
echo $redis->zrank('key', 'aaaa');   //結果:0 
echo $redis->zrevrank('key', 'aaaa');    //結果:1 
 
$redis->delete('key'); 
 
echo $redis->zincrby('key', 2, 'aaaa');  //結果:2 
echo $redis->zincrby('key', 1, 'aaaa');  //結果:3 
 
$redis->delete('key'); 
$redis->delete('test'); 
 
$redis->zadd('key', 0, 'val0'); 
$redis->zadd('key', 1, 'val1'); 
$redis->zadd('key', 4, 'val2'); 
$redis->zadd('test', 2, 'val2'); 
$redis->zadd('test', 3, 'val3'); 
$redis->zunion('k01', array('key', 'test')); 
print_r($redis->zrange('k01',0, -1)); //結果:Array ( [0] => val0 [1] => val1 [2] => val3 [3] => val2 ) 
 
$redis->zunion('k03', array('key', 'test'), array(5, 1)); 
print_r($redis->zrange('k03',0, -1)); //結果:Array ( [0] => val0 [1] => val3 [2] => val1 [3] => val2 )  
 
$redis->zinter('k02', array('key', 'test')); 
print_r($redis->zrange('k02',0, -1)); //結果:Array ( [0] => val2 ) 
?> 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.