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

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

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

PHP中PDO事務(wù)處理操作示例

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

這篇文章主要介紹了PHP中PDO事務(wù)處理操作,結(jié)合實(shí)例形式分析了php使用pdo的mysql事務(wù)處理操作步驟、實(shí)現(xiàn)技巧及相關(guān)注意事項(xiàng),需要的朋友可以參考下

本文實(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í)行語句...
$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ǔ)充:再來一個(gè)php使用PDO的mysql事務(wù)處理與回滾操作實(shí)例分析

概述:

事務(wù)(transaction)是由查詢和/或更新語句的序列組成。 用 begin、start transaction
開始一個(gè)事務(wù),rollback 回滾事務(wù),commit 提交事務(wù)。 在開始一個(gè)事務(wù)后,可以有若干個(gè) SQL 查詢或更新語句,每個(gè) SQL
遞交執(zhí)行后,還應(yīng)該有判斷是否正確執(zhí)行的語句,以確定下一步是否回滾,若都被正確執(zhí)行則最后提交事務(wù)。
事務(wù)一旦回滾,數(shù)據(jù)庫則保持開始事務(wù)前狀態(tài)。就好象一個(gè)被編輯的文件不存盤退出,自然還是保持文件原來的樣子。
所以,事務(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è)是通過設(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ù)庫連接失?。?quot;.$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

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 全是女性放屁角色的手游 | 美女脱衣有肉 | 久草在线福利资站免费视频 | 双子母性本能在线观看 | 国产区久久 | 国产馆精品推荐在线观看 | 日韩美女强理论片 | 精品欧美小视频在线观看 | 亚洲国产综合网 | 户外露出野战hd | 日本在线视频免费看 | 91精品婷婷国产综合久久8 | 操大姨子逼| 亚洲色图第四色 | 九草视频在线 | 亚洲、国产综合视频 | 国产精品久久国产三级国电话系列 | 天天综合网网欲色 | 欧美在线欧美 | 韩国理论三级在线观看视频 | 五月天网站 | 精品一区二区三区波多野结衣 | 日本护士撒尿 | 欧美xbxbxbbxxbb精品 | 亚洲精品m在线观看 | 99ri精品 | 美女的让男人桶爽30分钟的 | 国产乱码免费卡1卡二卡3卡四 | 欧美高清日韩 | 80日本xxxxxxxxx| 嗯啊视频在线 | 四虎成人免费视频 | 亚洲第一男人网站 | 日韩欧美成末人一区二区三区 | 小早川怜子息梦精在线播放 | 3d欧美人与禽交 | 成人免费视频一区二区三区 | 色哟哟哟 | www.四虎网站| 日本不卡免免费观看 | 18欧美同性videos可播放 |