佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例

PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例

熱門標(biāo)簽:阿里云 Linux服務(wù)器 服務(wù)器配置 團(tuán)購網(wǎng)站 電子圍欄 銀行業(yè)務(wù) Mysql連接數(shù)設(shè)置 科大訊飛語音識別系統(tǒng)

本文實(shí)例講述了PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作。分享給大家供大家參考,具體如下:

使用事務(wù)的好處:

舉個例子:銀行用戶A向用戶B轉(zhuǎn)賬100元,這個操作被分為兩個步驟:

(1)A的賬戶余額被扣去100。

(2)B的賬戶余額增加100。

如果不使用事務(wù)的話,假設(shè)(1)執(zhí)行成功了,而(2)失敗了,那用戶B沒有收到應(yīng)收款項(xiàng),而用戶A就白白受了損失。

使用事務(wù)之后,不論(1)或者(2)哪一步失敗,都可以回滾,即雙方的賬戶余額恢復(fù)到之前的狀態(tài)。

不是所有的數(shù)據(jù)庫都提供了對事務(wù)的支持,如mysql中的 Myisam 引擎不支持事務(wù),但新版本默認(rèn)使用的 innoDB 引擎提供了對事務(wù)的支持。(RDBMS大部分支持事務(wù),NoSQL數(shù)據(jù)庫一般不支持事務(wù))

下面來看具體的代碼:

?php
$dsn   = "mysql:dbname=pdo;host=localhost";
$user   = "root";
$password = "root";
$dbh   = new PDO($dsn, $user, $password);
//使用事務(wù)之前,要先關(guān)閉自動提交。不關(guān)閉的話,出現(xiàn)異常的時候沒法回滾。
//據(jù)手冊描述,ATTR_AUTOCOMMIT屬性只在mysql,OCI(oracle),firebird三種數(shù)據(jù)庫中可用
$dbh->setAttribute(PDO::ATTR_AUTOCOMMIT, 0);
$cash = 100;
try {
  $dbh->beginTransaction();
  //用戶A賬戶扣除100
  $sqlcmd    = "update transaction set useraccount=useraccount - {$cash} where username ='A'";
  $affected_rows = $dbh->exec($sqlcmd);
  if ($affected_rows > 0) {
    echo "用戶A賬戶扣除成功" . "br>";
  } else {
    throw new Exception("用戶A賬戶扣除失敗");
  }
  //用戶B賬戶增加100
  $affected_rows = $dbh->exec("update transaction set useraccount=useraccount+{$cash} where username ='B'");
  if ($affected_rows > 0) {
    echo "用戶B賬戶增加成功" . "br>";
  } else {
    throw new Exception("用戶B賬戶增加失敗");
  }
  echo "轉(zhuǎn)賬成功";
  //若前面兩個步驟都成功,則提交事務(wù)
  $dbh->commit();
}
catch (PDOException $e) //若前面兩個步驟中出現(xiàn)了異常,則回滾
  {
  echo $e->getMessage();
  $dbh->rollback();
}
//對事物的使用結(jié)束之后,重新開啟自動提交
$dbh->setAttribute(PDO::ATTR_AUTOCOMMIT, 1);
?>

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫程序設(shè)計技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設(shè)計有所幫助。

您可能感興趣的文章:
  • php PDO異常處理詳解
  • PHP中PDO的錯誤處理
  • php_pdo 預(yù)處理語句詳解
  • PHP中PDO的事務(wù)處理分析
  • php的PDO事務(wù)處理機(jī)制實(shí)例分析
  • PHP中PDO事務(wù)處理操作示例
  • php實(shí)現(xiàn)基于PDO的預(yù)處理示例
  • PHP的異常處理類Exception的使用及說明
  • PHP如何拋出異常處理錯誤
  • php實(shí)現(xiàn)的PDO異常處理操作分析

標(biāo)簽:衡水 棗莊 蚌埠 江蘇 衢州 廣元 大理 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    高碑店市| 内丘县| 黄山市| 鄂托克前旗| 盐源县| 韩城市| 丹寨县| 昌吉市| 乡城县| 文昌市| 宁远县| 萍乡市| 突泉县| 中山市| 四子王旗| 伊宁市| 会昌县| 东乌| 许昌县| 临西县| 渑池县| 唐海县| 博兴县| 扎赉特旗| 崇阳县| 旬邑县| 台安县| 建阳市| 全椒县| 常宁市| 南充市| 从化市| 宜州市| 习水县| 会理县| 博罗县| 武城县| 台中县| 上犹县| 托里县| 抚松县|