天天看點

pdo mysql 事務_PHP中PDO事務處理操作示例

本文執行個體講述了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驅動不支援.

執行個體:

try{

//最後是關閉自動送出

$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;

}

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程式設計有所幫助。