您好,登錄后才能下訂單哦!
這篇文章主要介紹了PHP中PDO事務(wù)處理的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
具體如下:
事務(wù)處理具有四個(gè)特性:原子性、一致性、獨(dú)立性、持久性。
并不是所有的數(shù)據(jù)庫(kù)都支持事務(wù)處理的,PDO 為能夠執(zhí)行事務(wù)處理的數(shù)據(jù)庫(kù)提供事務(wù)支持。
配置事務(wù)處理需注意:
1、關(guān)閉 PDO 的自動(dòng)提交;
$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, false);
2、開(kāi)啟一個(gè)事務(wù)需要的方法;
$pdo->beginTransaction(); // 開(kāi)啟一個(gè)事務(wù) $pdo->commit(); // 提交事務(wù) $pdo->rollback(); // 回滾事務(wù)
3、一般事務(wù)處理是運(yùn)行在 try...catch...語(yǔ)句中,當(dāng)事務(wù)失敗時(shí)執(zhí)行 catch 代碼段。
<?php try { $pdo->beginTransaction(); // 開(kāi)啟一個(gè)事務(wù) $row = null; $row = $pdo->exec("xxx"); // 執(zhí)行第一個(gè) SQL if (!$row) throw new PDOException('提示信息或執(zhí)行動(dòng)作'); // 如出現(xiàn)異常提示信息或執(zhí)行動(dòng)作 $row = $pdo->exec("xxx"); // 執(zhí)行第二個(gè) SQL if (!$row) throw new PDOException('提示信息或執(zhí)行動(dòng)作'); $pdo->commit(); } catch (PDOException $e) { $pdo->rollback(); // 執(zhí)行失敗,事務(wù)回滾 exit($e->getMessage()); } ?>
在事務(wù)中的 SQL 語(yǔ)句,如果出現(xiàn)錯(cuò)誤,那么所有的 SQL 都不執(zhí)行。當(dāng)所有 SQL 有無(wú)誤的時(shí)候,才提交執(zhí)行。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“PHP中PDO事務(wù)處理的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。