[PHP]MySQL的wait_timeout与pdo对象
2023-02-18 15:41:20 时间
1.查看和设置mysql的wait_timeout的值
SHOW GLOBAL VARIABLES LIKE '%timeout%';
设置wait_timeout的值
SET GLOBAL wait_timeout=10;
2.当程序中有超过10秒的执行后,再次去执行一条sql语句 , 就会报错
Warning: Error while sending QUERY packet 或者 MySQL server has gone away
3.因此我们在使用单例的PDO对象的时候,要进行时间上的判断,比如我上面的例子,超过10秒的PDO对象,要重新new一下
<?php $option=array(); $timeout=time()+10; $pdo=new PDO("mysql:host=localhost;dbname=my_test","root","xxxx",$option); var_dump($pdo); /* object(PDO)#1 (0) { } */ //此时执行了一个11秒时间的操作 sleep(11); var_dump($pdo); /* object(PDO)#1 (0) { } */ //此时需要重新new一下PDO对象,才可以继续操作,否则报错 if($timeout<time()){ $pdo=new PDO("mysql:host=localhost;dbname=my_test","root","xxxxx",$option); } $pdo->query('set names utf8'); $sth=$pdo->prepare("select * from index_test"); $sth->execute(array("id"=>2000)); $res=$sth->fetchAll(); print_r($res);
相关文章
- 忙活了一年的开源社区,终于赶上了春节前的末班车!
- ChatGPT 会开源吗?
- 7 款殿堂级的开源 CMS(内容管理系统)
- 请收下这 10 个安全相关的开源项目
- MySQL 5.7 升级到 8.0
- 越折腾越好用的 3 款开源 APP
- 10 款更先进的开源命令行工具
- 对开源框架跃跃欲试,却在写的时候犯了难?
- 一大波开源小抄来袭
- 物联网?快来看 Arduino 上云啦
- 想做钢铁侠?听说很多大佬都是用它入门的
- 写给小白的开源编译器
- 支持中文!秒建 wiki 知识库的开源项目,构建私人知识网络
- 一款开源的文件搜索神器,终于不用记 find 命令了
- 用一个文件,实现迷你 Web 框架
- 一个文件的开源项目,开启你的开源之旅
- 3.6 万颗星!开源 Web 服务器后起之秀,自带免费 HTTPS 开箱即用
- 狠人!标星 3.4 万的项目说删就删,几行代码搞崩数万个开源项目
- 那些年的开源项目,你跑起来了吗?
- 重玩 40 年前的经典游戏小蜜蜂,这次通关了源码