国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

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

2024-05-05 00:03:32
字體:
供稿:網(wǎng)友

本文實例講述了PHP中PDO事務(wù)處理操作。分享給大家供大家參考,具體如下:

概要:

將多條sql操作(增刪改)作為一個操作單元,要么都成功,要么都失敗。

單條數(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)錯誤處理}

示例:

$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("提交失敗!");}

補充:再來一個php使用PDO的mysql事務(wù)處理與回滾操作實例分析

概述:

事務(wù)(transaction)是由查詢和/或更新語句的序列組成。 用 begin、start transaction
開始一個事務(wù),rollback 回滾事務(wù),commit 提交事務(wù)。 在開始一個事務(wù)后,可以有若干個 SQL 查詢或更新語句,每個 SQL
遞交執(zhí)行后,還應(yīng)該有判斷是否正確執(zhí)行的語句,以確定下一步是否回滾,若都被正確執(zhí)行則最后提交事務(wù)。
事務(wù)一旦回滾,數(shù)據(jù)庫則保持開始事務(wù)前狀態(tài)。就好象一個被編輯的文件不存盤退出,自然還是保持文件原來的樣子。
所以,事務(wù)可被視為原子操作,事務(wù)中的 SQL,要么全部執(zhí)行,要不一句都不執(zhí)行。

PHP中PDO的MYSQL事務(wù)處理步驟:

①.關(guān)閉自動提交

②.開啟事務(wù)處理

③.有異常就自動拋出異常提示再回滾

④.開啟自動提交

注意:

mysql只有這個InnoDB驅(qū)動是支持事務(wù)處理的,默認(rèn)MyIsAM驅(qū)動不支持.

實例:

<?phptry{//最后是關(guān)閉自動提交$pdo=new pdo("mysql:host=localhost;dbname=mydb","root","root", array(PDO::ATTR_AUTOCOMMIT=>0));//這個是通過設(shè)置屬性方法進行關(guān)閉自動提交和上面的功能一樣//$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, 0);//開啟異常處理$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);}catch(PDOException $e){echo "數(shù)據(jù)庫連接失敗:".$e->getMessage();exit;}/** 事務(wù)處理** 張三從李四那里買了一臺 2000 元的電腦* 從張三帳號中扣出 2000元* 向李四賬號中加入 2000元* 從商品表中減少一臺電腦* 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)出失敗");//那個錯誤拋出異常$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();}//自動提交,如果最后不自動提交,轉(zhuǎn)賬是不成功的$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);//設(shè)置錯誤報告模式 ERRMODE_SILENT ERRMODE_WARNING

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


注:相關(guān)教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 沙洋县| 灵璧县| 长汀县| 聂拉木县| 中牟县| 思茅市| 宁国市| 华亭县| 阜南县| 高阳县| 阳曲县| 唐河县| 潼南县| 永泰县| 宜昌市| 长丰县| 沂源县| 天峻县| 蒙城县| 东方市| 九江县| 新平| 万年县| 图木舒克市| 新津县| 神木县| 太仆寺旗| 来凤县| 荥经县| 孟村| 锦屏县| 平果县| 北碚区| 新沂市| 海兴县| 大厂| 类乌齐县| 湖口县| 桂阳县| 桂阳县| 石嘴山市|