PHP中PDO交易處理操作樣本

來源:互聯網
上載者:User
這篇文章主要介紹了PHP中PDO交易處理操作,結合執行個體形式分析了php使用pdo的mysql交易處理操作步驟、實現技巧及相關注意事項,需要的朋友可以參考下

本文執行個體講述了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
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.