php實(shí)現(xiàn)基于pdo的事務(wù)處理方法示例
本文實(shí)例講述了php實(shí)現(xiàn)基于pdo的事務(wù)處理方法。分享給大家供大家參考,具體如下:
實(shí)例1:
try {} catch () {} 形式
<?php $dsn = 'mysql:dbname=cheyun_cms;host=127.0.0.1'; $user = 'root'; $password = '111111'; //采用預(yù)處理+事務(wù)處理執(zhí)行SQL操作 //1.連接數(shù)據(jù)庫(kù) try { $pdo = new PDO($dsn, $user, $password); $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); } catch (PDOException $e) { die("數(shù)據(jù)庫(kù)連接失敗".$e->getMessage()); } //2.執(zhí)行數(shù)據(jù)操作 try{ //開啟事物,此時(shí)會(huì)關(guān)閉自動(dòng)提交 $pdo->beginTransaction(); $sql = "insert into cy_log (logid, value, action, file) values (?, ?, ?, ?)"; $stmt = $pdo->prepare($sql); //傳入?yún)?shù) $stmt->execute(array(null,"test4","w",11)); $stmt->execute(array(null,"test5","w",11)); $stmt->execute(array(null,"test3","w",11)); //提交事物,并且 數(shù)據(jù)庫(kù)連接返回到自動(dòng)提交模式 $pdo->commit(); }catch(PDOException $e){ echo '執(zhí)行失敗'.$e->getMessage(); //如果數(shù)據(jù)庫(kù)被設(shè)置成自動(dòng)提交模式,rollback 在回滾事務(wù)之后將恢復(fù)自動(dòng)提交模式。 //包括 MySQL 在內(nèi)的一些數(shù)據(jù)庫(kù), 當(dāng)在一個(gè)事務(wù)內(nèi)有類似刪除或創(chuàng)建數(shù)據(jù)表等 DLL 語(yǔ)句時(shí),會(huì)自動(dòng)導(dǎo)致一個(gè)隱式地提交。 //隱式地提交將無(wú)法回滾此事務(wù)范圍內(nèi)的任何更改。即 DDL 語(yǔ)句無(wú)法回滾 $pdo->rollback(); }
實(shí)例2:
if…else…形式
<?php $dsn = 'mysql:dbname=cheyun_cms;host=127.0.0.1'; $user = 'root'; $password = '111111'; //采用預(yù)處理+事務(wù)處理執(zhí)行SQL操作 //1.連接數(shù)據(jù)庫(kù) try { $pdo = new PDO($dsn, $user, $password); } catch (PDOException $e) { die("數(shù)據(jù)庫(kù)連接失敗".$e->getMessage()); } //2.執(zhí)行數(shù)據(jù)操作 //開啟事物 $pdo->beginTransaction(); $sql = "insert into cy_log (logid, value, action, file) values (?, ?, ?, ?)"; $stmt = $pdo->prepare($sql); $datalist = array( array(null,"test9","w",11), array(null,"test10","w",11), array(null,"test11","w",11) ); //是否提交標(biāo)志位 $isCommit = true; foreach($datalist as $data){ $stmt->execute($data); if($stmt->errorCode()>0){ //回滾 $pdo->rollback(); $isCommit = false; break; } } if($isCommit){ //提交事物 $pdo->commit(); }
注意:
數(shù)據(jù)表需要 InnoDB 類型
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫(kù)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
解析php curl_setopt 函數(shù)的相關(guān)應(yīng)用及介紹
本篇文章是對(duì)php中的curl_setopt函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP中array_merge和array相加的區(qū)別分析
今天處理一個(gè)這樣的問(wèn)題:如何獲取字符鍵名相同值不同的兩個(gè)數(shù)組值集合,用array_merge和數(shù)組相加都不可行,讓我認(rèn)真比較了下PHP中array_merge和array相加的區(qū)別2013-06-06php關(guān)鍵字僅替換一次的實(shí)現(xiàn)函數(shù)
這篇文章主要介紹了php實(shí)現(xiàn)每個(gè)關(guān)鍵字僅需要替換一次,有時(shí)一個(gè)項(xiàng)目里面涉及到批量替換關(guān)鍵字的問(wèn)題,本文針對(duì)控制替換次數(shù)進(jìn)行研究,感興趣的小伙伴們可以參考一下2015-10-10PHP連接SQL server數(shù)據(jù)庫(kù)測(cè)試腳本運(yùn)行實(shí)例
這篇文章主要介紹了PHP連接SQL server數(shù)據(jù)庫(kù)測(cè)試腳本運(yùn)行實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08php中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解
下面小編就為大家?guī)?lái)一篇php中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02PHP連接MySQL數(shù)據(jù)庫(kù)并以json格式輸出
PHP連接數(shù)據(jù)庫(kù)有多種方法,現(xiàn)介紹常用的MySQL數(shù)據(jù)庫(kù)連接方法,PHP連接MySQL也有兩種方式,一是面向?qū)ο?,二是面向過(guò)程方式,兩種方法稍有區(qū)別。下面通過(guò)代碼介紹兩種方法連接MySQL并以json格式輸出2018-05-05