一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP中PDO事務處理操作示例

PHP中PDO事務處理操作示例

2019-10-09 15:10橡皮擦Mid PHP教程

這篇文章主要介紹了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驅動不支持.

實例:

<?php
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;
}
/*
* 事務處理
*
* 張三從李四那里買了一臺 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程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 俄罗斯一级毛片免费播放 | 免费在线观看伦理片 | 四虎精品成人a在线观看 | www.天天操| 国产婷婷成人久久av免费高清 | 黑人草 | 天美网站传媒入口网址 | 高h辣h双处全是肉军婚 | 视频一区二区在线 | 国产精品久久久久久久午夜片 | 小草高清视频免费直播 | 新新电影理论中文字幕 | 免费被靠视频动漫 | 草啪啪| 黑人巨摘花第一次出血 | 日韩在线 中文字幕 | 鬼吹灯天星术在线高清观看 | 99re这里只有精品视频在线观看 | 69罗莉视频在线观看 | 国产拍拍拍免费专区在线观看 | 人妖女天堂视频在线96 | 欧美同志gaypronvideos | 91国产在线视频 | 婷婷色在线 | 日本人妖视频 | 成人区精品一区二区毛片不卡 | 欧美一区二区日韩一区二区 | 99热这里只有精品久久免费 | 日本阿v精品视频在线观看 日本xxx片免费高清在线 | 四虎影库网址 | 手机看片1024国产 | gangbang日本 | 久久热这里面只有精品 | 国产一区日韩二区欧美三 | 国产99精品 | 免看一级a一片成人123 | 掰开逼操| 女同久久另类99精品国产 | 欧美大片一区 | 蜜色影院| 99热久久这里只有精品6国产网 |