百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

PHP中使用redis函数的正确使用方法(实例)

mhr18 2024-10-21 05:46 36 浏览 0 评论

$redis = new Redis();

$redis->connect('127.0.0.1',6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接

$redis->open('127.0.0.1',6379,1);//短链接(同上)

$redis->pconnect('127.0.0.1',6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接

$redis->popen('127.0.0.1',6379,1);//长链接(同上)

$redis->auth('password');//登录验证密码,返回【true | false

$redis->select(0);//选择redis库,0~15 共16个库

$redis->close();//释放资源

$redis->ping(); //检查是否还再链接,[+pong]

$redis->ttl('key');//查看失效时间[-1 | timestamps]

$redis->persist('key');//移除失效时间[ 1 | 0]

$redis->sort('key',[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]

/*2.共性的运算归类*/

$redis->expire('key',10);//设置失效时间[true | false]

$redis->move('key',15);//把当前库中的key移动到15库中[0|1]

//string

$redis->strlen('key');//获取当前key的长度

$redis->append('key','string');//把string追加到key现有的value中[追加后的个数]

$redis->incr('key');//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]

$redis->incrby('key',$num);//自增$num,不存在为赋值,值需为整数[new_num | false]

$redis->decr('key');//自减1,[new_num | false]

$redis->decrby('key',$num);//自减$num,[ new_num | false]

$redis->setex('key',10,'value');//key=value,有效期为10秒[true]

//list

$redis->llen('key');//返回列表key的长度,不存在key返回0, [ len | 0]

//set

$redis->scard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]

$redis->sMove('key1', 'key2', 'member');//移动,将member元素从key1集合移动到key2集合。[1 | 0]

//Zset

$redis->zcard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]

$redis->zcount('key',0,-1);//返回有序集key中,score值在minmax之间(默认包括score值等于minmax)的成员。[num | 0]

//hash

$redis->hexists('key','field');//查看hash中是否存在field,[1 | 0]

$redis->hincrby('key','field',$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]

$redis->hlen('key');//返回哈希表key中域的数量。[ num | 0]

/*3.Server*/

$redis->dbSize();//返回当前库中的key的个数

$redis->flushAll();//清空整个redis[总true]

$redis->flushDB();//清空当前redis库[总true]

$redis->save();//同步??把数据存储到磁盘-dump.rdb[true]

$redis->bgsave();//异步??把数据存储到磁盘-dump.rdb[true]

$redis->info();//查询当前redis的状态 [verson:2.4.5....]

$redis->lastSave();//上次存储时间key的时间[timestamp]

$redis->watch('key','keyn');//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]

$redis->unwatch('key','keyn');//取消监视一个(或多个) key [true]

$redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。

$redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。

$redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false

/*4.String,键值对,创建更新同操作*/

$redis->setOption(Redis::OPT_PREFIX,'hf_');//设置表前缀为hf_

$redis->set('key',1);//设置key=aa value=1 [true]

$redis->mset($arr);//设置一个或多个键值[true]

$redis->setnx('key','value');//key=value,key存在返回false[|true]

$redis->get('key');//获取key [value]

$redis->mget($arr);//(string|arr),返回所查询键的值

$redis->del($key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】

$redis->delete($key_str,$key2,$key3);//删除keys,[del_num]

$redis->getset('old_key','new_value');//先获得key的值,然后重新赋值,[old_value | false]

/*5.List栈的结构,注意表头表尾,创建更新分开操作*/

$redis->lpush('key','value');//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false]

$redis->rpush('key','value');//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]

$redis->lInsert('key', Redis::AFTER, 'value', 'new_value');//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]

$redis->lpushx('key','value');//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]

$redis->rpushx('key','value');//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]

$redis->lpop('key');//删,移除并返回列表key的头元素,[被删元素 | false]

$redis->rpop('key');//删,移除并返回列表key的尾元素,[被删元素 | false]

$redis->lrem('key','value',0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value) [被移除的数量 | 0]

$redis->ltrim('key',start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]

$redis->lset('key',index,'new_v');//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]

$redis->lindex('key',index);//查,返回列表key中,下标为index的元素[value|false]

$redis->lrange('key',0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]

/*6.Set,没有重复的member,创建更新同操作*/

$redis->sadd('key','value1','value2','valuen');//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]

$redis->srem('key','value1','value2','valuen');//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]

$redis->smembers('key');//查,返回集合key中的所有成员 [array | '']

$redis->sismember('key','member');//判断member元素是否是集合key的成员 [1 | 0]

$redis->spop('key');//删,移除并返回集合中的一个随机元素 [member | false]

$redis->srandmember('key');//查,返回集合中的一个随机元素 [member | false]

$redis->sinter('key1','key2','keyn');//查,返回所有给定集合的交集 [array | false]

$redis->sunion('key1','key2','keyn');//查,返回所有给定集合的并集 [array | false]

$redis->sdiff('key1','key2','keyn');//查,返回所有给定集合的差集 [array | false]

/*7.Zset,没有重复的member,有排序顺序,创建更新同操作*/

$redis->zAdd('key',$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]

$redis->zrem('key','member1','membern');//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]

$redis->zscore('key','member');//查,通过值反拿权 [num | null]

$redis->zrange('key',$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]

$redis->zrevrange('key',$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]

$redis->zrangebyscore('key',$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]

$redis->zrevrangebyscore('key',$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]

$redis->zrank('key','member');//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]

$redis->zrevrank('key','member');//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]

$redis->ZINTERSTORE();//交集

$redis->ZUNIONSTORE();//差集

/*8.Hash,表结构,创建更新同操作*/

$redis->hset('key','field','value');//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】

$redis->hget('key','field');//查,取值【value|false

$arr = array('one'=>1,2,3);$arr2 = array('one',0,1);

$redis->hmset('key',$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]

$redis->hmget('key',$arr2);//查,获取指定下标的field,[$arr | false]

$redis->hgetall('key');//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]

$redis->hkeys('key');//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]

$redis->hvals('key');//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]

$redis->hdel('key',$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]

相关推荐

订单超时自动取消业务的 N 种实现方案,从原理到落地全解析

在分布式系统架构中,订单超时自动取消机制是保障业务一致性的关键组件。某电商平台曾因超时处理机制缺陷导致日均3000+订单库存锁定异常,直接损失超50万元/天。本文将从技术原理、实现细节、...

使用Spring Boot 3开发时,如何选择合适的分布式技术?

作为互联网大厂的后端开发人员,当你满怀期待地用上SpringBoot3,准备在项目中大显身手时,却发现一个棘手的问题摆在面前:面对众多分布式技术,究竟该如何选择,才能让SpringBoot...

数据库内存爆满怎么办?99%的程序员都踩过这个坑!

你的数据库是不是又双叒叕内存爆满了?!服务器监控一片红色警告,老板在群里@所有人,运维同事的电话打爆了手机...这种场景是不是特别熟悉?别慌!作为一个在数据库优化这条路上摸爬滚打了10年的老司机,今天...

springboot利用Redisson 实现缓存与数据库双写不一致问题

使用了Redisson来操作Redis分布式锁,主要功能是从缓存和数据库中获取商品信息,以下是针对并发时更新缓存和数据库带来不一致问题的解决方案1.基于读写锁和删除缓存策略在并发更新场景下,...

外贸独立站数据库炸了?对象缓存让你起死回生

上周黑五,一个客户眼睁睁看着服务器CPU飙到100%——每次页面加载要查87次数据库。这让我想起2024年Pantheon的测试:Redis缓存能把WooCommerce查询速度提升20倍。跨境电商最...

手把手教你在 Spring Boot3 里纯编码实现自定义分布式锁

为什么要自己实现分布式锁?你是不是早就受够了引入各种第三方依赖时的繁琐?尤其是分布式锁这块,每次集成Redisson或者Zookeeper,都得额外维护一堆配置,有时候还会因为版本兼容问题头疼半...

如何设计一个支持百万级实时数据推送的WebSocket集群架构?

面试解答:要设计一个支持百万级实时数据推送的WebSocket集群架构,需从**连接管理、负载均衡、水平扩展、容灾恢复**四个维度切入:连接层设计-**长连接优化**:采用Netty或Und...

Redis数据结构总结——面试最常问到的知识点

Redis作为主流的nosql存储,面试时经常会问到。其主要场景是用作缓存,分布式锁,分布式session,消息队列,发布订阅等等。其存储结构主要有String,List,Set,Hash,Sort...

skynet服务的缺陷 lua死循环

服务端高级架构—云风的skynet这边有一个关于云风skynet的视频推荐给大家观看点击就可以观看了!skynet是一套多人在线游戏的轻量级服务端框架,使用C+Lua开发。skynet的显著优点是,...

七年Java开发的一路辛酸史:分享面试京东、阿里、美团后的心得

前言我觉得有一个能够找一份大厂的offer的想法,这是很正常的,这并不是我们的饭后谈资而是每个技术人的追求。像阿里、腾讯、美团、字节跳动、京东等等的技术氛围与技术规范度还是要明显优于一些创业型公司...

mysql mogodb es redis数据库之间的区别

1.MySQL应用场景概念:关系型数据库,基于关系模型,使用表和行存储数据。优点:支持ACID事务,数据具有很高的一致性和完整性。缺点:垂直扩展能力有限,需要分库分表等方式扩展。对于复杂的查询和大量的...

redis,memcached,nginx网络组件

1.理解阻塞io,非阻塞io,同步io,异步io的区别2.理解BIO和AIO的区别io多路复用只负责io检测,不负责io操作阻塞io中的write,能写多少是多少,只要写成功就返回,譬如准备写500字...

SpringBoot+Vue+Redis实现验证码功能

一个小时只允许发三次验证码。一次验证码有效期二分钟。SpringBoot整合Redis...

AWS MemoryDB 可观测最佳实践

AWSMemoryDB介绍AmazonMemoryDB是一种完全托管的、内存中数据存储服务,专为需要极低延迟和高吞吐量的应用程序而设计。它与Redis和Memcached相似,但具有更...

从0构建大型AI推荐系统:实时化引擎从工具到生态的演进

在AI浪潮席卷各行各业的今天,推荐系统正从幕后走向前台,成为用户体验的核心驱动力。本文将带你深入探索一个大型AI推荐系统从零起步的全过程,揭示实时化引擎如何从单一工具演进为复杂生态的关键路径。无论你是...

取消回复欢迎 发表评论: