婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP中PDO事務處理操作示例

PHP中PDO事務處理操作示例

熱門標簽:寧波外呼營銷系統(tǒng) 長沙做地圖標注公司 遼寧ai電銷機器人價格 上海做外呼線路的通信公司 地圖標注專員怎么樣 電話機器人銷售主要負責什么 房產(chǎn)中介用的是什么外呼系統(tǒng) 四川保險智能外呼系統(tǒng)供應商 福建銀行智能外呼系統(tǒng)價格

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

概要:

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

單條數(shù)據(jù)不用事務處理

被操作的表必須是innoDB類型的表(支持事務)

MySQL常用的表類型:MyISAM(非事務)增刪改速度快、InnodB(事務型)安全性高

更改表的類型為innoDB類型

mysql> alter table stu engine=innodb;

使用:

在PDO預處理的基礎上添加,如下格式:

try{
$m->beginTransaction();//開啟事務處理
//PDO預處理以及執(zhí)行語句...
$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
遞交執(zhí)行后,還應該有判斷是否正確執(zhí)行的語句,以確定下一步是否回滾,若都被正確執(zhí)行則最后提交事務。
事務一旦回滾,數(shù)據(jù)庫則保持開始事務前狀態(tài)。就好象一個被編輯的文件不存盤退出,自然還是保持文件原來的樣子。
所以,事務可被視為原子操作,事務中的 SQL,要么全部執(zhí)行,要不一句都不執(zhí)行。

PHP中PDO的MYSQL事務處理步驟:

①.關閉自動提交

②.開啟事務處理

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

④.開啟自動提交

注意:

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

實例:

?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 "數(shù)據(jù)庫連接失敗:".$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相關內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結》、《php+Oracle數(shù)據(jù)庫程序設計技巧總結》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O計入門教程》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

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

您可能感興趣的文章:
  • php PDO異常處理詳解
  • PHP中PDO的錯誤處理
  • php_pdo 預處理語句詳解
  • PHP中PDO的事務處理分析
  • php的PDO事務處理機制實例分析
  • php實現(xiàn)基于PDO的預處理示例
  • PHP使用pdo實現(xiàn)事務處理操作示例
  • PHP的異常處理類Exception的使用及說明
  • PHP如何拋出異常處理錯誤
  • php實現(xiàn)的PDO異常處理操作分析

標簽:宜春 工商登記 佛山 澳門 常德 深圳 宿遷 延安

巨人網(wǎng)絡通訊聲明:本文標題《PHP中PDO事務處理操作示例》,本文關鍵詞  PHP,中,PDO,事務處理,操作,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP中PDO事務處理操作示例》相關的同類信息!
  • 本頁收集關于PHP中PDO事務處理操作示例的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 万源市| 崇文区| 新安县| 克什克腾旗| 东辽县| 扎囊县| 都匀市| 龙泉市| 丰顺县| 九龙坡区| 岐山县| 西充县| 定州市| 盐山县| 天峨县| 杭锦旗| 志丹县| 林口县| 永宁县| 昌宁县| 阜城县| 台江县| 和龙市| 逊克县| 家居| 图木舒克市| 汨罗市| 玉树县| 玉环县| 吉安县| 南昌市| 登封市| 自治县| 南丰县| 蒙阴县| 黎川县| 甘泉县| 七台河市| 正宁县| 长武县| 鄂托克前旗|