溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

PHP中PDO事務(wù)處理的示例分析

發(fā)布時(shí)間:2021-08-31 11:43:52 來(lái)源:億速云 閱讀:138 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了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í)!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI