前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[PHP]MySQL的wait_timeout与pdo对象

[PHP]MySQL的wait_timeout与pdo对象

作者头像
唯一Chat
发布2019-09-10 11:09:01
1.1K0
发布2019-09-10 11:09:01
举报
文章被收录于专栏:陶士涵的菜地陶士涵的菜地

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一下

代码语言:javascript
复制
<?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);
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-03-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档