需要用到sleep函數定時從數據庫取一堆數據出來去執行某些操作。
sleep等待的時間至少有一個小時以上
此前做過測試
用sleep函數去完成數小時后執行的操作是可行的

可邪門的問題出來了
程序用sleep " /> 国产毛片网站,狠狠鲁视频,欧美精品一区二区三区免费播放

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

PHP中使用sleep造成mysql讀取失敗的案例和解決方法

近日,由于項目需求
需要用到sleep函數定時從數據庫取一堆數據出來去執行某些操作。
sleep等待的時間至少有一個小時以上
此前做過測試
用sleep函數去完成數小時后執行的操作是可行的
 
可邪門的問題出來了
程序用sleep后發現不能從數據庫取到相應的信息
把sleep去掉
結果正常
 
郁悶中。。。
難道sleep影響讀庫操作?。。?br />于是為了方便測試
直接來個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會導致單例類超時問題從而出現執行時間過長以后數據庫連接可能斷開問題,也就不能讀到數據庫信息!

php技術PHP中使用sleep造成mysql讀取失敗的案例和解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 孙东杓| 日本电影家庭教师| 曹永廉| 小矮人的一级毛片| 廖君| 无声无息电影| 生猴子视频| 偏偏喜欢你演员表| 汤姆·塞兹摩尔| 大场久美子| 卜冠今| 我和我的祖国钢琴谱完整版| 在线播放啄木乌丝袜秘书| 那根所有权| 李乃文宋丹丹朱媛媛演的电视剧 | 九龙城寨在线观看| 通灵之王| 暗夜尖叫1988美国版高清观看| 特种部队3浴血追凶| 日本大片网址| 王艺婵| 辕门外三声炮歌词| 李坤忆| 夏希粟| 故宫博物院思维导图| 美女xxx69爽爽免费观妞| 连城诀1-40集全集免费| 声入人心| 美人鱼公主| 电视剧昨夜星辰| 瓯江潮涨潮落时间表| 九龙城寨在线观看| 40集电视连续剧人生之路| 大奉打更人电视剧免费在线观看| 美女不穿衣服| 奈哈·西贡索邦| 日本午夜电影| 操蛋视频| 经典伦理电影| 大国崛起思维导图| 每天一分钱每天翻一倍连续30天|