redis php 实例二

前面一篇博客主要是string类型,list类型和set类型,下面hash类型和zset类型

1,hset

描述:将哈希表key中的域field的值设为value。如果key不存在,一个新的哈希表被创建并进行HSET操作。如果域field已经存在于哈希表中,旧值将被覆盖。
参数:key field value
返回值:如果field是哈希表中的一个新建域,并且值设置成功,返回1。如果哈希表中域field已经存在且旧值已被新值覆盖,返回0。

实例1

2,hsetnx

描述:将哈希表key中的域field的值设置为value,当且仅当域field不存在。若域field已经存在,该操作无效。如果key不存在,一个新哈希表被创建并执行HSETNX命令。
参数:key field value
返回值:设置成功,返回1。如果给定域已经存在且没有操作被执行,返回0。

实例1

3,hget

描述:返回哈希表key中给定域field的值。
参数:key field
返回值:给定域的值。当给定域不存在或是给定key不存在时,返回nil。

实例1

4,hmset

描述:同时将多个field - value(域-值)对设置到哈希表key中。此命令会覆盖哈希表中已存在的域。如果key不存在,一个空哈希表被创建并执行HMSET操作。
参数:key field value [field value ...]
返回值:如果命令执行成功,返回OK。当key不是哈希表(hash)类型时,返回一个错误。

实例1

5,hmget

描述:返回哈希表key中,一个或多个给定域的值。如果给定的域不存在于哈希表,那么返回一个nil值。因为不存在的key被当作一个空哈希表来处理,所以对一个不存在的key进行HMGET操作将返回一个只带有nil值的表。
参数:key field [field ...]
返回值:一个包含多个给定域的关联值的表,表值的排列顺序和给定域参数的请求顺序一样。

实例1

6,hgetall

描述:返回哈希表key中,所有的域和值。在返回值里,紧跟每个域名(field name)之后是域的值(value),所以返回值的长度是哈希表大小的两倍。
参数:key
返回值:以列表形式返回哈希表的域和域的值。 若key不存在,返回空列表。

实例1

7,hdel

描述:删除哈希表key中的一个或多个指定域,不存在的域将被忽略。
参数:key field [field ...]
返回值:被成功移除的域的数量,不包括被忽略的域。

实例1

8,hlen

描述:返回哈希表key中域的数量。
参数:key
返回值:哈希表中域的数量。当key不存在时,返回0。

实例1

9,hexists

描述:查看哈希表key中,给定域field是否存在。
参数:key field
返回值:如果哈希表含有给定域,返回1。如果哈希表不含有给定域,或key不存在,返回0。

实例1

10,hincrby

描述:为哈希表key中的域field的值加上增量increment。增量也可以为负数,相当于对给定域进行减法操作。
参数:key field increment
返回值:执行HINCRBY命令之后,哈希表key中域field的值。

实例1

11,hkeys

描述:返回哈希表key中的所有域。
参数:key
返回值:一个包含哈希表中所有域的表。当key不存在时,返回一个空表。

实例1

12,hvals

描述:返回哈希表key中的所有值。
参数:key
返回值:一个包含哈希表中所有值的表。当key不存在时,返回一个空表。
实例1

  1. <?php  
  2. $redis = new redis();  
  3. $redis->connect('192.168.1.108', 6379);  
  4. $redis->delete('test');  
  5. $redis->hset('test''key1''hello');  
  6. echo $redis->hget('test''key1');     //结果:hello  
  7.   
  8. echo "<br>";  
  9. $redis->hSetNx('test''key1''world');  
  10. echo $redis->hget('test''key1');   //结果:hello  
  11.   
  12. $redis->delete('test');  
  13. $redis->hSetNx('test''key1''world');  
  14. echo "<br>";  
  15. echo $redis->hget('test''key1');   //结果:world  
  16.   
  17. echo $redis->hlen('test');   //结果:1  
  18. var_dump($redis->hdel('test','key1'));  //结果:bool(true)   
  19.   
  20. $redis->delete('test');  
  21. $redis->hSet('test''a''x');  
  22. $redis->hSet('test''b''y');  
  23. $redis->hSet('test''c''z');  
  24. print_r($redis->hkeys('test'));  //结果:Array ( [0] => a [1] => b [2] => c )   
  25.   
  26. print_r($redis->hvals('test'));  //结果:Array ( [0] => x [1] => y [2] => z )   
  27.   
  28. print_r($redis->hgetall('test'));  //结果:Array ( [a] => x [b] => y [c] => z )   
  29.   
  30. var_dump($redis->hExists('test''a'));  //结果:bool(true)   
  31.   
  32. $redis->delete('test');  
  33. echo $redis->hIncrBy('test''a', 3);    //结果:3  
  34. echo $redis->hIncrBy('test''a', 1);    //结果:4  
  35.   
  36. $redis->delete('test');  
  37. var_dump($redis->hmset('test'array('name' =>'tank''sex'=>"man"))); //结果:bool(true)  
  38. print_r($redis->hmget('test'array('name''sex')));  //结果:Array ( [name] => tank [sex] => man )  
  39. ?>  

13,zadd

描述:
增加一个或多个元素,如果该元素已经存在,更新它的socre值
虽然有序集合有序,但它也是集合,不能重复元素,添加重复元素只会
更新原有元素的score值

参数:
key
score : double
value: string

返回值:1 or 0

实例2

14,zrange

描述:取得特定范围内的排序元素,0代表第一个元素,1代表第二个以此类推。-1代表最后一个,-2代表倒数第二个...

参数:
key
start: long
end: long
withscores: bool = false

返回值:数组

实例2

15,zdelete, zrem

描述:从有序集合中删除指定的成员。

参数:
key
member

返回值:1 or 0

实例2

16,zrevrange

描述:返回key对应的有序集合中指定区间的所有元素。这些元素按照score从高到低的顺序进行排列。对于具有相同的score的元素而言,将会按照递减的字典顺序进行排列。该命令与ZRANGE类似,只是该命令中元素的排列顺序与前者不同。

参数:
key
start: long
end: long
withscores: bool = false

返回值:数组

实例2

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

返回值:数组

实例2

18,zcount

描述:返回key对应的有序集合中介于min和max间的元素的个数。

参数:
key
start: string
end: string

返回值:数组长度

实例2

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

返回值:删除元素个数

实例2

20,zremrangebyrank, zdeleterangebyrank

描述:移除key对应的有序集合中rank值介于start和stop之间的所有元素。start和stop均是从0开始的,并且两者均可以是负值。当索引值为负值时,表明偏移值从有序集合中score值最高的元素开始。例如:-1表示具有最高score的元素,而-2表示具有次高score的元素,以此类推。

参数:
key
start: LONG
end: LONG

返回值:删除元素个数

实例2

21,zsize, zcard

描述:返回存储在key对应的有序集合中的元素的个数。
参数:key
返回值:元素个数

实例2

22,zscore

描述:返回key对应的有序集合中member的score值。如果member在有序集合中不存在,那么将会返回null。
参数:key member

实例2

23,zrank, zrevrank

描述:返回key对应的有序集合中member元素的索引值,元素按照score从低到高进行排列。rank值(或index)是从0开始的,这意味着具有最低score值的元素的rank值为0。使用ZREVRANK可以获得从高到低排列的元素的rank(或index)。
参数:key member
返回值:数字

实例2

24,zincrby

将key对应的有序集合中member元素的scroe加上increment。如果指定的member不存在,那么将会添加该元素,并且其score的初始值为increment。如果key不存在,那么将会创建一个新的有序列表,其中包含member这一唯一的元素。如果key对应的值不是有序列表,那么将会发生错误。指定的score的值应该是能够转换为数字值的字符串,并且接收双精度浮点数。同时,你也可用提供一个负值,这样将减少score的值。
参数:key value member
返回值:字符型数据

实例2

25,zunion

描述:keys对应的numkeys个有序集合计算合集,并将结果存储在destination中
参数:keyOutput arrayZSetKeys arrayWeights aggregateFunction
返回值:并集数组

实例2

26,zinter

描述:keys对应的numkeys个有序集合计算交集,并将结果存储在destination中
参数:keyOutput arrayZSetKeys arrayWeights aggregateFunction
返回值:交集数组

实例2

  1. $redis = new redis();  
  2. $redis->connect('192.168.1.108', 6379);  
  3. $redis->delete('test');  
  4. $redis->zadd('test', 1, 'val1');  
  5. $redis->zadd('test', 0, 'val2');  
  6. $redis->zadd('test', 3, 'val3');  
  7.   
  8. print_r($redis->zrange('test', 0, -1)); //结果:Array ( [0] => val2 [1] => val1 [2] => val3 )  
  9.   
  10. $redis->zdelete('test''val2');  
  11. print_r($redis->zrange('test', 0, -1)); //结果:Array ( [0] => val1 [1] => val3 )   
  12.   
  13. $redis->zadd('test',4, 'val0');  
  14. print_r($redis->zrevrange('test', 0, -1));  //结果:Array ( [0] => val0 [1] => val3 [2] => val1 )  
  15. print_r($redis->zrevrange('test', 0, -1,true));  //结果:Array ( [val0] => 4 [val3] => 3 [val1] => 1 )   
  16.   
  17. echo "<br>";  
  18. $redis->zadd('key', 0, 'val0');  
  19. $redis->zadd('key', 2, 'val2');  
  20. $redis->zadd('key', 10, 'val10');  
  21.   
  22. print_r($redis->zrangebyscore('key', 0, 3, array('limit' => array(1, 1),'withscores' => TRUE))); //结果:Array ( [val2] => 2 )  
  23. print_r($redis->zrangebyscore('key', 0, 3, array('limit' => array(1, 1)))); //结果:Array ( [0] => val2 )   
  24.   
  25. echo $redis->zcount('key', 0, 3); //结果:2  
  26.   
  27. $redis->zremrangebyscore('key', 0, 3);  
  28. print_r($redis->zrange('key', 0, -1));  //结果:Array ( [0] => val10 )   
  29.   
  30. echo $redis->zsize('key');   //结果:1  
  31.   
  32. $redis->zadd('key', 2.5, 'aaaa');  
  33. echo $redis->zscore('key''aaaa');   //结果:2.5  
  34.   
  35. echo $redis->zrank('key''aaaa');   //结果:0  
  36. echo $redis->zrevrank('key''aaaa');    //结果:1  
  37.   
  38. $redis->delete('key');  
  39.   
  40. echo $redis->zincrby('key', 2, 'aaaa');  //结果:2  
  41. echo $redis->zincrby('key', 1, 'aaaa');  //结果:3  
  42.   
  43. $redis->delete('key');  
  44. $redis->delete('test');  
  45.   
  46. $redis->zadd('key', 0, 'val0');  
  47. $redis->zadd('key', 1, 'val1');  
  48. $redis->zadd('key', 4, 'val2');  
  49. $redis->zadd('test', 2, 'val2');  
  50. $redis->zadd('test', 3, 'val3');  
  51. $redis->zunion('k01'array('key''test'));  
  52. print_r($redis->zrange('k01',0, -1)); //结果:Array ( [0] => val0 [1] => val1 [2] => val3 [3] => val2 )  
  53.   
  54. $redis->zunion('k03'array('key''test'), array(5, 1));  
  55. print_r($redis->zrange('k03',0, -1)); //结果:Array ( [0] => val0 [1] => val3 [2] => val1 [3] => val2 )   
  56.   
  57. $redis->zinter('k02'array('key''test'));  
  58. print_r($redis->zrange('k02',0, -1)); //结果:Array ( [0] => val2 )  
  59. ?>  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值