php操作redis中的hash和zset类型数据的方法和代码例子_php实例

 前面一篇博客主要是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 ) 
?> 

时间: 2024-09-25 02:33:52

php操作redis中的hash和zset类型数据的方法和代码例子_php实例的相关文章

30个php操作redis常用方法代码例子_php实例

 redis的操作很多的,以前看到一个比较全的博客,但是现在找不到了.查个东西搜半天,下面整理一下php处理redis的例子,个人觉得常用一些例子.下面的例子都是基于php-redis这个扩展的. 1,connect 描述:实例连接到一个Redis. 参数:host: string,port: int 返回值:BOOL 成功返回:TRUE;失败返回:FALSE 示例: 复制代码 代码如下: <?php  $redis = new redis();  $result = $redis->conn

PHP中使用file_get_contents post数据代码例子_php实例

废话不多说,上代码: 复制代码 代码如下: $data = array(     'name' => 'Joe',     'website' => 'www.jb51.net' ); $data = http_build_query($data); $data = json_encode($data); $json = file_get_contents($url, 0, stream_context_create(array(     'http' => array(        

使用node.js中的Buffer类处理二进制数据的方法_node.js

前言 在Node.js中,定义了一个Buffer类,该类用来创建一个专门存放二进制数据的缓存区.这篇文章就详细介绍了node.js中的Buffer类处理二进制数据的方法,下面话不多说,来看看详细的介绍. 创建Buffer对象 第一种:直接使用一个数组来初始化缓存区 var arr = [0,1,2] var buf = new Buffer(arr) console.log(buf) 执行效果: 第二种:直接使用一个字符串来初始化缓存区 var str = 'hello' var buf = n

Excel表格中使用单变量求解分析数据的方法

  Excel表格中使用单变量求解分析数据的方法           1.打开工作簿,创建工作表,并在工作表中输入数据,同时在B10单元格中输入公式"=SUM(B3:B9)"计算费用总和,如图1所示. 图1 创建工作表 2.在"数据"选项卡的"数据工具"组中单击"模拟分析"按钮,在打开的下拉列表中选择"单变量求解"选项,如图2所示. 图2 选择"单变量求解"选项 3.打开"单变

填充Excel表中上方非空单元格数据的方法

填充Excel表中上方非空单元格数据的方法   1.选择范围 将需要填写的空单元格以及其上方单元格一起选中 2.定位空值 同时按住ctrl+G,跳出"定位"对话框,点击"定位条件" 在弹出的"定位条件"对话款,选中"空值',并确定,这样,空白单元格全被选中 3.输入公式 输入"="和第一个空单元格上方单元格的地址(A2),如下图,输入完成后,同时按住ctrl+enter,即可

codeigniter中view通过循环显示数组数据的方法

 这篇文章主要介绍了codeigniter中view通过循环显示数组数据的方法,实例分析了codeigniter中view方法与数组遍历的技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了codeigniter中view通过循环显示数组数据的方法.分享给大家供大家参考.具体如下: controller如下: ? 1 2 3 4 5 6 7 8 9 10 <?php class SimpleController extends Controller { function in

c++-C#中的string或者char类型数据如何转化为C++中的char类型数据

问题描述 C#中的string或者char类型数据如何转化为C++中的char类型数据 C++代码:bool hasfire(char s[100]) 因为使用C++做DLL文件,调用hasfire()这个函数时,发现C#中的char类型和C++中的不大一样,不知道怎么处理才能把C#中的char转化成C++中的char类型.

车辆分割中角点分割-opencv车辆分割中角点选择并连线分割方法和代码

问题描述 opencv车辆分割中角点选择并连线分割方法和代码 就是已经得到了重合车辆的很多角点,现在需要选择真正的角点来连线进行分割,不知道怎么写代码. 解决方案 你这个车辆有重合,应该怎么检测效果好一些,我就不太清楚了, 不知道能不能参考矩形检测的方法:矩形检测http://blog.csdn.net/wangyaninglm/article/details/43959947 解决方案二: 试用动态分析,使用重合前各车的图片,去识别重合后车辆.

java-jdbc中向MySQL传String类型数据

问题描述 jdbc中向MySQL传String类型数据 jdbc中向MySQL传String类型数据,还有jdbc中添加,删除,修改信息的代码,以及然后添加窗口背景图片 解决方案 关于MySQL到JDBC类型映射 解决方案二: http://www.cnblogs.com/wuyuegb2312/p/3872607.html