时间:2021-05-26
近日,由于项目需求
需要用到sleep函数定时从数据库取一堆数据出来去执行某些操作。
sleep等待的时间至少有一个小时以上
此前做过测试
用sleep函数去完成数小时后执行的操作是可行的
可邪门的问题出来了
程序用sleep后发现不能从数据库取到相应的信息
把sleep去掉
结果正常
郁闷中。。。
难道sleep影响读库操作!!!
于是为了方便测试
直接来个sleep(10) 十秒后执行
结果能从数据库读取信息
可为什么sleep()一个小时后不能读取信息呢?
为了测试方便我直接在sleep语句前读库一次,sleep后再读一次库
如:
复制代码 代码如下:
<?php
require_once('include.php');
// 读取数据库信息
$data = $db->getList();
print_r($data);
// 定时一个小时以后
sleep(3600);
// 再读取一次信息
$data = $db->getList();
print_r($data);
?>
结果发现
第一次读库成功
第二次读库为空
于是再把sleep改成十秒钟后再测试一次
复制代码 代码如下:
<?php
require_once('include.php');
// 读取数据库信息
$data = $db->getList();
print_r($data);
// 定时十秒以后
sleep(10);
// 再读取一次信息
$data = $db->getList();
print_r($data);
?>
以上结果
两次读库成功
为何一个小时读库失败,十秒钟却读库成功呢??
我用的是单例数据库操作类
想起一个问题
会不会是数据库连接超时导致读库失败呢?
于是赶紧把此处读库操作改成现连
复制代码 代码如下:
<?php
require_once('include.php');
// 读取数据库信息
$data = getList();
print_r($data);
// 定时一个小时以后
sleep(3600);
// 再读取一次信息
$data = getList();
print_r($data);
// 读取数据库信息
function getList(){
$pdo = new PDO('mysql:host=localhost;dbname=test','root','root');
$result = $pdo->query('select * from tables');
return $result->fetchAll(PDO::FETCH_ASSOC);
}
?>
测试成功!!
原来sleep会导致单例类超时问题从而出现执行时间过长以后数据库连接可能断开问题,也就不能读到数据库信息!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例分析了php查询mysql大量数据造成内存不足的解决方法。分享给大家供大家参考。具体分析如下:一、问题使用php查询mysql大数据量的时候,程序尚未执
有时候在使用新浪微博发私信的时候会遇到失败的情况,这是为什么呢?该怎么解决呢?今天小编就将新浪微博私信发送失败的原因和解决方法告诉大家新浪微博发送私信失败解决办
户户通电视锅出现E02智能卡通讯失败的原因和解决方法: 1、智能卡与机顶盒的卡槽接触不良导致读取信息发生通讯失败,可以将机顶盒关机,拔出智能卡,用橡皮擦擦拭一
卫星锅E02智能卡通讯失败的原因和解决方法: 1、智能卡与机顶盒的卡槽接触不良导致读取信息发生通讯失败,可以将机顶盒关机,拔出智能卡,用橡皮擦擦拭一下智能卡的
台式电脑开不了机的故障自检和解决方法。大家都知道,电脑开不了机是比较常见的故障之一,然而造成这种结果可能有很多原因,那么接下来小编给大家带来故障自检和解决方法,