php Redis函数使用总结(string,hash,list, set , sort set )

摘要:
string、set、sortset和hash的添加和修改操作是同一个命令,但当操作被修改时,及时成功的返回值仍然为0。对于:list结构,添加、删除、修改和查询都有自己的一组方法。57$redis-˃exec();//在所有事务块中执行命令,;58596061/*4.字符串、键值对、创建和更新与*/62$redis-˃setOption//将表前缀设置为hf_63$redis-˃Set;//Set key=aavalue=1[true]64$redis-˃mset//设置一个或多个键值[true]65$redis-˃setnx//key=value,return false[|true]66$redis-˃get if the key exists//get key[value]67$redis˃mget;//,返回查询键68$redis-˃del//Delete键的值,支持数组批量删除69$redis-˃de
 

对于:string, set , sort set , hash 的增,改操作,是同一个命令,但是把它当改操作时,及时成功返回值依旧为0

对于:list结构来说,增删改查自有一套方法。
 
复制代码
  1 <?php
  2 /*1.Connection*/
  3    $redis = new Redis();
  4    $redis->connect('127.0.0.1',6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接
  5    $redis->open('127.0.0.1',6379,1);//短链接(同上)
  6    $redis->pconnect('127.0.0.1',6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接
  7    $redis->popen('127.0.0.1',6379,1);//长链接(同上)
  8    $redis->auth('password');//登录验证密码,返回【true | false】
  9    $redis->select(0);//选择redis库,0~15 共16个库
 10    $redis->close();//释放资源
 11    $redis->ping(); //检查是否还再链接,[+pong]
 12    $redis->ttl('key');//查看失效时间[-1 | timestamps]
 13    $redis->persist('key');//移除失效时间[ 1 | 0]
 14    $redis->sort('key',[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]
 15 
 16 
 17 /*2.共性的运算归类*/
 18    $redis->expire('key',10);//设置失效时间[true | false]
 19    $redis->move('key',15);//把当前库中的key移动到15库中[0|1]
 20 
 21 //string
 22    $redis->strlen('key');//获取当前key的长度
 23    $redis->append('key','string');//把string追加到key现有的value中[追加后的个数]
 24    $redis->incr('key');//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]
 25    $redis->incrby('key',$num);//自增$num,不存在为赋值,值需为整数[new_num | false]
 26    $redis->decr('key');//自减1,[new_num | false]
 27    $redis->decrby('key',$num);//自减$num,[ new_num | false]
 28    $redis->setex('key',10,'value');//key=value,有效期为10秒[true]
 29 //list
 30    $redis->llen('key');//返回列表key的长度,不存在key返回0, [ len | 0]
 31 //set
 32    $redis->scard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]
 33    $redis->sMove('key1', 'key2', 'member');//移动,将member元素从key1集合移动到key2集合。[1 | 0]
 34 //Zset
 35    $redis->zcard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]
 36    $redis->zcount('key',0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
 37 //hash
 38    $redis->hexists('key','field');//查看hash中是否存在field,[1 | 0]
 39    $redis->hincrby('key','field',$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]
 40    $redis->hlen('key');//返回哈希表key中域的数量。[ num | 0]
 41 
 42 
 43 
 44 /*3.Server*/
 45    $redis->dbSize();//返回当前库中的key的个数
 46    $redis->flushAll();//清空整个redis[总true]
 47    $redis->flushDB();//清空当前redis库[总true]
 48    $redis->save();//同步??把数据存储到磁盘-dump.rdb[true]
 49    $redis->bgsave();//异步??把数据存储到磁盘-dump.rdb[true]
 50    $redis->info();//查询当前redis的状态 [verson:2.4.5....]
 51    $redis->lastSave();//上次存储时间key的时间[timestamp]
 52 
 53    $redis->watch('key','keyn');//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]
 54    $redis->unwatch('key','keyn');//取消监视一个(或多个) key [true]
 55    $redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
 56    $redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
 57    $redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】
 58 
 59 
 60 
 61 /*4.String,键值对,创建更新同操作*/
 62    $redis->setOption(Redis::OPT_PREFIX,'hf_');//设置表前缀为hf_
 63    $redis->set('key',1);//设置key=aa value=1 [true]
 64    $redis->mset($arr);//设置一个或多个键值[true]
 65    $redis->setnx('key','value');//key=value,key存在返回false[|true]
 66    $redis->get('key');//获取key [value]
 67    $redis->mget($arr);//(string|arr),返回所查询键的值
 68    $redis->del($key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】
 69    $redis->delete($key_str,$key2,$key3);//删除keys,[del_num]
 70    $redis->getset('old_key','new_value');//先获得key的值,然后重新赋值,[old_value | false]
 71 
 72 
 73 
 74 /*5.List栈的结构,注意表头表尾,创建更新分开操作*/
 75    $redis->lpush('key','value');//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false]
 76    $redis->rpush('key','value');//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]
 77    $redis->lInsert('key', Redis::AFTER, 'value', 'new_value');//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]
 78    $redis->lpushx('key','value');//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]
 79    $redis->rpushx('key','value');//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]
 80    $redis->lpop('key');//删,移除并返回列表key的头元素,[被删元素 | false]
 81    $redis->rpop('key');//删,移除并返回列表key的尾元素,[被删元素 | false]
 82    $redis->lrem('key','value',0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value)  [被移除的数量 | 0]
 83    $redis->ltrim('key',start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]
 84    $redis->lset('key',index,'new_v');//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]
 85    $redis->lindex('key',index);//查,返回列表key中,下标为index的元素[value|false]
 86    $redis->lrange('key',0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]
 87 
 88 /*6.Set,没有重复的member,创建更新同操作*/
 89    $redis->sadd('key','value1','value2','valuen');//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]
 90    $redis->srem('key','value1','value2','valuen');//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]
 91    $redis->smembers('key');//查,返回集合key中的所有成员 [array | '']
 92    $redis->sismember('key','member');//判断member元素是否是集合key的成员 [1 | 0]
 93    $redis->spop('key');//删,移除并返回集合中的一个随机元素 [member | false]
 94    $redis->srandmember('key');//查,返回集合中的一个随机元素 [member | false]
 95    $redis->sinter('key1','key2','keyn');//查,返回所有给定集合的交集 [array | false]
 96    $redis->sunion('key1','key2','keyn');//查,返回所有给定集合的并集 [array | false]
 97    $redis->sdiff('key1','key2','keyn');//查,返回所有给定集合的差集 [array | false]
 98 
 99 
100 /*7.Zset,没有重复的member,有排序顺序,创建更新同操作*/
101    $redis->zAdd('key',$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]
102    $redis->zrem('key','member1','membern');//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]
103    $redis->zscore('key','member');//查,通过值反拿权 [num | null]
104    $redis->zrange('key',$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
105    $redis->zrevrange('key',$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
106    $redis->zrangebyscore('key',$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]
107    $redis->zrevrangebyscore('key',$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]
108    $redis->zrank('key','member');//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
109    $redis->zrevrank('key','member');//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]
110    $redis->ZINTERSTORE();//交集
111    $redis->ZUNIONSTORE();//差集
112 
113 /*8.Hash,表结构,创建更新同操作*/
114    $redis->hset('key','field','value');//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】
115    $redis->hget('key','field');//查,取值【value|false】
116    $arr = array('one'=>1,2,3);$arr2 = array('one',0,1);
117    $redis->hmset('key',$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]
118    $redis->hmget('key',$arr2);//查,获取指定下标的field,[$arr | false]
119    $redis->hgetall('key');//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]
120    $redis->hkeys('key');//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]
121    $redis->hvals('key');//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]
122    $redis->hdel('key',$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]
123 
124 ?>
复制代码
 转载自:https://www.cnblogs.com/zuochuang/p/8242796.html
 
 

免责声明:文章转载自《php Redis函数使用总结(string,hash,list, set , sort set )》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇k8s集群如何暴露端口给外部访问Java中的内部接口下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Python环境搭建

Python下载 Python最新源码,二进制文档,新闻资讯等可以在Python的官网查看到: Python官网:http://www.python.org/ 你可以在以下链接中下载 Python 的文档,你可以下载 HTML、PDF 和 PostScript 等格式的文档。 Python文档下载地址:www.python.org/doc/ Window...

Objective-C调用Swift

如果已经有了一个老的iOS应用,它是使用Objective-C编写的,而它的一些新功能需要采用Swift来编写,这时就可以从Objective-C调用Swift。 Objective-C调用Swift时不需要桥接头文件,而是需要Xcode生成的头文件。这种文件由Xcode生成,不需要我们维护,对于开发人员也是不可见的。如下图所示,它能够将Swift中的类暴...

Spring Data Redis入门示例:数据序列化 (四)

概述 RedisTemplate默认使用的是基于JDK的序列化器,所以存储在Redis的数据如果不经过相应的反序列化,看到的结果是这个样子的: 可以看到,出现了乱码,在程序层面上,不会影响程序的运行,但当出现数据错误,对数据进行排查时,就无从下手了。 序列化器 在Spring Data Redis中,用户自定义类型和存储数据之间的转换(反之亦然)由org...

C#中ArrayList 与 string、string[]数组 的转换

1、ArrarList 转换为 string[] :ArrayList list = new ArrayList();list.Add("aaa");list.Add("bbb");//转换成数组string[] arrString = (string[])list.ToArray(typeof( string)) ;2、string[] 转换为 Arra...

Redis限流的实现方式有3种

Redis限流的实现方式有3种,分别是:1、基于Redis的setnx的操作,给指定的key设置了过期实践;2、基于Redis的数据结构zset,将请求打造成一个zset数组;3、基于Redis的令牌桶算法,输出速率大于输入速率,就要限流。 第一种:基于Redis的setnx的操作 我们在使用Redis的分布式锁的时候,大家都知道是依靠了setnx的指令,...

php反射

反射 //反射查找对象方法所在的文件名。$n_func = new ReflectionMethod($obj,$function);$filepath = $n_func->getFileName();var_dump($filepath); //反射查找类的文件名$class = new ReflectionClass(($obj);$exten...