以下是【金聰采編】分享的內容全文:
本文實例講述了PHP中PDO事務處理操作。分享給大家供大家參考,具體如下:
概要:
將多條sql操作(增刪改)作為一個操作單元,要么都成功,要么都失敗。
單條數據不用事務處理
被操作的表必須是innoDB類型的表(支持事務)
MySQL常用的表類型:MyISAM(非事務)增刪改速度快、InnodB(事務型)安全性高
更改表的類型為innoDB類型
mysql> alter table stu engine=innodb;
使用:
在PDO預處理的基礎上添加,如下格式:
try{$m->beginTransaction();//開啟事務處理//PDO預處理以及執行語句...$m->commit();//提交事務}catch(PDOException $e){$m->rollBack();//事務回滾//相關錯誤處理}示例:
$m = new PDO($dsn,$user,$pwd);$m->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);try{$m->beginTransaction();//開啟事務處理$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("提交失敗!");}補充:再來一個php使用PDO的mysql事務處理與回滾操作實例分析
概述:
事務(transaction)是由查詢和/或更新語句的序列組成。 用 begin、start transaction
開始一個事務,rollback 回滾事務,commit 提交事務。 在開始一個事務后,可以有若干個 SQL 查詢或更新語句,每個 SQL
遞交執行后,還應該有判斷是否正確執行的語句,以確定下一步是否回滾,若都被正確執行則最后提交事務。
事務一旦回滾,數據庫則保持開始事務前狀態。就好象一個被編輯的文件不存盤退出,自然還是保持文件原來的樣子。
所以,事務可被視為原子操作,事務中的 SQL,要么全部執行,要不一句都不執行。
PHP中PDO的MYSQL事務處理步驟:
①.關閉自動提交
②.開啟事務處理
③.有異常就自動拋出異常提示再回滾
④.開啟自動提交
注意:
mysql只有這個InnoDB驅動是支持事務處理的,默認MyIsAM驅動不支持.
實例:
<?phptry{//最后是關閉自動提交$pdo=new pdo("mysql:host=localhost;dbname=mydb","root","root", array(PDO::ATTR_AUTOCOMMIT=>0));//這個是通過設置屬性方法進行關閉自動提交和上面的功能一樣//$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, 0);//開啟異常處理$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);}catch(PDOException $e){echo "數據庫連接失敗:".$e->getMessage();exit;}/** 事務處理** 張三從李四那里買了一臺 2000 元的電腦* 從張三帳號中扣出 2000元* 向李四賬號中加入 2000元* 從商品表中減少一臺電腦* MyIsAM InnoDB*/try{$pdo->beginTransaction();//開啟事務處理$price=500;$sql="update zhanghao set price=price-{$price} where id=1";$affected_rows=$pdo->exec($sql);if(!$affected_rows)throw new PDOException("張三轉出失敗");//那個錯誤拋出異常$sql="update zhanghao set price=price+{$price} where id=3";$affected_rows=$pdo->exec($sql);if(!$affected_rows)throw new PDOException("向李四轉入失敗");echo "交易成功!";$pdo->commit();//交易成功就提交}catch(PDOException $e){echo $e->getMessage();$pdo->rollback();}//自動提交,如果最后不自動提交,轉賬是不成功的$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);//設置錯誤報告模式 ERRMODE_SILENT ERRMODE_WARNING更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP基于pdo操作數據庫技巧總結》、《php+Oracle數據庫程序設計技巧總結》、《PHP+MongoDB數據庫操作技巧大全》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
1.軟件源碼推廣展示:目的展示軟件相關功能,接收技術學習者測試、測評;
2.教程課程信息展示:展示課程信息,傳授課程各階段內容;
3.設計素材圖片展示:展示素材設計理念、思維方式、傳播設計理念;
4.福利優惠信息展示:分享各類最新的福利信息,各種優惠信息展示;
以上分享目的僅供學習、參考使用,請勿用于其他用途,如果想商業使用或者代理,請自行聯系版權方獲取授權。任何未獲取授權的商業使用與本站無關,請自行承擔相應責任。
本站不存儲任何資源文件,敬請周知!
如果您認為本頁信息內容侵犯了您的相關權益(包含但不限于:著作權、首發權、隱私權等權利),或者您認為自己是此信息的權利人但是此信息不是自己發布的,可以直接版權舉報投訴,我們會根據網站注冊協議、資源分享協議等協議處理,以保護您的合法權益。
本網站采用 BY-NC-SA 協議進行授權 轉載請注明原文鏈接:PHP中PDO事務處理操作示例

侵權舉報/版權申訴



