PHP中PDO事務(wù)處理操作示例
本文實(shí)例講述了PHP中PDO事務(wù)處理操作。分享給大家供大家參考,具體如下:
概要:
將多條sql操作(增刪改)作為一個(gè)操作單元,要么都成功,要么都失敗。
單條數(shù)據(jù)不用事務(wù)處理
被操作的表必須是innoDB類型的表(支持事務(wù))
MySQL常用的表類型:MyISAM(非事務(wù))增刪改速度快、InnodB(事務(wù)型)安全性高
更改表的類型為innoDB類型
mysql> alter table stu engine=innodb;
使用:
在PDO預(yù)處理的基礎(chǔ)上添加,如下格式:
try{ $m->beginTransaction();//開啟事務(wù)處理 //PDO預(yù)處理以及執(zhí)行語(yǔ)句... $m->commit();//提交事務(wù) }catch(PDOException $e){ $m->rollBack();//事務(wù)回滾 //相關(guān)錯(cuò)誤處理 }
示例:
$m = new PDO($dsn,$user,$pwd); $m->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); try{ $m->beginTransaction();//開啟事務(wù)處理 $stmt=$m->prepare("insert into stu(name,sex,age,classid)values(?,?,?,?)"); $data=array( array("user1",1,22,"lamp76"), array("user2",1,20,"lamp76"), array("user3",0,22,"lamp76") ); foreach($data as $v){ $stmt->execute($v); echo $m->lastInsertId(); } $m->commit(); echo "提交成功!"; }catch(PDOException $e){ $m->rollBack();//回滾 die("提交失敗!"); }
補(bǔ)充:再來(lái)一個(gè)php使用PDO的mysql事務(wù)處理與回滾操作實(shí)例分析
概述:
事務(wù)(transaction)是由查詢和/或更新語(yǔ)句的序列組成。 用 begin、start transaction
開始一個(gè)事務(wù),rollback 回滾事務(wù),commit 提交事務(wù)。 在開始一個(gè)事務(wù)后,可以有若干個(gè) SQL 查詢或更新語(yǔ)句,每個(gè) SQL
遞交執(zhí)行后,還應(yīng)該有判斷是否正確執(zhí)行的語(yǔ)句,以確定下一步是否回滾,若都被正確執(zhí)行則最后提交事務(wù)。
事務(wù)一旦回滾,數(shù)據(jù)庫(kù)則保持開始事務(wù)前狀態(tài)。就好象一個(gè)被編輯的文件不存盤退出,自然還是保持文件原來(lái)的樣子。
所以,事務(wù)可被視為原子操作,事務(wù)中的 SQL,要么全部執(zhí)行,要不一句都不執(zhí)行。
PHP中PDO的MYSQL事務(wù)處理步驟:
①.關(guān)閉自動(dòng)提交
②.開啟事務(wù)處理
③.有異常就自動(dòng)拋出異常提示再回滾
④.開啟自動(dòng)提交
注意:
mysql只有這個(gè)InnoDB驅(qū)動(dòng)是支持事務(wù)處理的,默認(rèn)MyIsAM驅(qū)動(dòng)不支持.
實(shí)例:
<?php try{ //最后是關(guān)閉自動(dòng)提交 $pdo=new pdo("mysql:host=localhost;dbname=mydb","root","root", array(PDO::ATTR_AUTOCOMMIT=>0)); //這個(gè)是通過(guò)設(shè)置屬性方法進(jìn)行關(guān)閉自動(dòng)提交和上面的功能一樣 //$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, 0); //開啟異常處理 $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); }catch(PDOException $e){ echo "數(shù)據(jù)庫(kù)連接失敗:".$e->getMessage(); exit; } /* * 事務(wù)處理 * * 張三從李四那里買了一臺(tái) 2000 元的電腦 * 從張三帳號(hào)中扣出 2000元 * 向李四賬號(hào)中加入 2000元 * 從商品表中減少一臺(tái)電腦 * MyIsAM InnoDB */ try{ $pdo->beginTransaction();//開啟事務(wù)處理 $price=500; $sql="update zhanghao set price=price-{$price} where id=1"; $affected_rows=$pdo->exec($sql); if(!$affected_rows) throw new PDOException("張三轉(zhuǎn)出失敗");//那個(gè)錯(cuò)誤拋出異常 $sql="update zhanghao set price=price+{$price} where id=3"; $affected_rows=$pdo->exec($sql); if(!$affected_rows) throw new PDOException("向李四轉(zhuǎn)入失敗"); echo "交易成功!"; $pdo->commit();//交易成功就提交 }catch(PDOException $e){ echo $e->getMessage(); $pdo->rollback(); } //自動(dòng)提交,如果最后不自動(dòng)提交,轉(zhuǎn)賬是不成功的 $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1); //設(shè)置錯(cuò)誤報(bào)告模式 ERRMODE_SILENT ERRMODE_WARNING
更多關(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常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php中配置文件操作 如config.php文件的讀取修改等操作
對(duì)形如config.php文件的讀取,修改等操作的代碼,需要的朋友可以參考下2012-07-07php封裝的數(shù)據(jù)庫(kù)函數(shù)與用法示例【參考thinkPHP】
這篇文章主要介紹了php封裝的數(shù)據(jù)庫(kù)函數(shù)與用法,基于thinkPHP中數(shù)據(jù)庫(kù)操作相關(guān)代碼整理簡(jiǎn)化而來(lái),包括針對(duì)數(shù)據(jù)庫(kù)的設(shè)置、連接、查詢及日志操作等功能,簡(jiǎn)單實(shí)用,需要的朋友可以參考下2016-11-11延長(zhǎng)phpmyadmin登錄時(shí)間的方法
新安裝的phpmyadmin默認(rèn)是cookie模式,如果閑置十幾分鐘不操作的話,就會(huì)要求重新登錄。2011-02-02php設(shè)置靜態(tài)內(nèi)容緩存時(shí)間的方法
這篇文章主要介紹了php設(shè)置靜態(tài)內(nèi)容緩存時(shí)間的方法,涉及針對(duì)header函數(shù)中參數(shù)的應(yīng)用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12php select,radio和checkbox默認(rèn)選擇的實(shí)現(xiàn)方法
radio和checkbox默認(rèn)選擇的實(shí)現(xiàn)方法,大家參考下原理就知道了,不論asp,asp.net,jsp都是這個(gè)原理。2010-05-05PHP小偷程序的設(shè)計(jì)與實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP小偷程序的設(shè)計(jì)與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了php基于HTML解析類實(shí)現(xiàn)小偷程序抓取圖片的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2016-10-10