濮阳杆衣贸易有限公司

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

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

熱門標(biāo)簽:企業(yè)400電話辦理多少費(fèi)用 神龍斗士電話機(jī)器人 萍鄉(xiāng)商鋪地圖標(biāo)注 宿州正規(guī)外呼系統(tǒng)軟件 合肥企業(yè)外呼系統(tǒng)線路 電信外呼系統(tǒng)多少錢一個月 桂陽公司如何做地圖標(biāo)注 代理打電話機(jī)器人 太原400電話申請流程

本文實(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è)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

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

您可能感興趣的文章:
  • 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)簽:崇左 白銀 鄂州 衡陽 廊坊 綏化 辛集 太原

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例》,本文關(guān)鍵詞  PHP,使用,pdo,實(shí)現(xiàn),事務(wù)處理,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    临颍县| 阿尔山市| 抚顺县| 乐都县| 文山县| 棋牌| 全州县| 广昌县| 怀化市| 姜堰市| 庆阳市| 海南省| 溧阳市| 炉霍县| 扎鲁特旗| 凤冈县| 健康| 越西县| 通城县| 丰宁| 阿鲁科尔沁旗| 札达县| 定襄县| 临江市| 寿阳县| 武强县| 龙里县| 昌宁县| 巧家县| 蓝山县| 信丰县| 鸡东县| 吉木乃县| 贺兰县| 忻城县| 奉化市| 镇雄县| 东阳市| 怀化市| 五莲县| 南雄市|