一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

PHP中執行MYSQL事務解決數據寫入不完整等情況

近來稍有時間研究了下MYSQL中的事務操作,在很多場合下很是適用,譬如在注冊的時候需要初始化很多張關聯表的時候,問答回復的時候需要至少同時操作兩張表,這些都會在某些時候只能成功更新一張表,而另外的SQL語句出現錯誤,正常的操作會導致初始化了一張表 ,其他的都木有能初始化,這個時候就會導致用戶表里的用戶信息已經執行插入,導致提示注冊失敗,但是用戶已經注冊了部分信息,這個時候需要程序員去數據庫刪除相應的數據是一個比較不好的事情。

因此這邊考慮使用事務,事務可以進行模擬SQL操作,當所有的SQL都操作成功的時候才進行SQL操作,只要有一個操作失敗就回滾當前事務的所有SQL操作,避免出現上面描述中出現的數據寫入不完整等情況。

下面是鄙人寫的一小段代碼,歡迎大家參考和提出意見:
復制代碼 代碼如下:
/**
* @todo 多條sql的事務處理
* @param $sqls array
* @return boole true/false
*/
public function doArraySqlActionsTran($password,$sqls){
$db = $this -> doSqlLink($password);//打開數據庫鏈接
$db -> autocommit(FALSE);//設置為不自動提交,因為MYSQL默認立即執行
//獲取SQL執行結果數組
for ($i=0;$i<count($sqls);$i++){
$result[$i] = $db -> query($sqls[$i]);
}
//解析SQL執行結果數組
for ($j=0;$j<count($result);$j++){
if ($result[$j]==FALSE){
$result[$j]='false';
}else{
$result[$j]='true';
}
}
//查找SQL結果數組中是否存在false結果集
if (in_array('false',$result)){
$sqlResult=FALSE;
}else{
$sqlResult==TRUE;
}
//根據結果集進行數據庫回滾或者執行操作
if ($sqlResult==FALSE){
$db -> rollback();//判斷當執行失敗時回滾
$return=FALSE;// 正式環境中使用
//$return='ROOLBACK';//test 標記使用
}else{
$db -> commit();//執行事務s
$return=TRUE;// 正式環境中使用
//$return='COMMIT';//test 標記使用
}
$db->autocommit(true); //設置為非自動提交――事務處理
$db->close();//關閉連接
return $return;
}

到此事務執行批量SQL操作基本完成,謝謝大家!

php技術PHP中執行MYSQL事務解決數據寫入不完整等情況,轉載需保留來源!

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

主站蜘蛛池模板: 日韩在线观看中文字幕 | 婷婷六月激情在线综合激情 | 日本一二三区免费 | 激情婷婷成人亚洲综合 | 亚洲国产成人久久综合野外 | 大尺度福利视频 | 国产三级级在线观看大学生 | 视频一区二区三区在线 | 成人在线亚洲 | 欧美激情在线精品一区二区 | 国产91精品高清一区二区三区 | 国产特黄1级毛片 | 国产精品亚洲欧美一级久久精品 | 男人把女人c爽的免费视频 男人操女人免费视频 | 亚洲高清视频一区 | 性做久久久久 | 久久r热这里有精品视频 | 亚洲福利视频网 | 在线播放真实国产乱子伦 | 夜色资源站www国产在线资源 | 国产97色在线中文 | 国产成人精品精品欧美 | 国产欧美性综合视频性刺激 | 男人狂躁戳女人下免费看 | 色狠狠狠狠综合影视 | 在线观看国产一区二区三区99 | 亚洲国产成人最新精品资源 | 国模大胆一区二区三区 | 极品美女一区二区三区 | 婷婷丁香花麻豆 | 2021中国大陆精品视频xxxx | 最新97超级碰碰碰碰久久久久 | 精品国偷自产在线 | 日本激情一区二区三区 | 精品视频午夜一区二区 | 色免费在线观看 | 最近更新中文字幕第一页 | 久久亚洲欧美日本精品品 | 日韩α片 | 99成人在线观看 | 国产精彩刺激对白视频 |