主頁(yè) > 知識(shí)庫(kù) > PHP中PDO事務(wù)處理操作示例

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

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

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

概要:

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

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

被操作的表必須是innoDB類(lèi)型的表(支持事務(wù))

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

更改表的類(lèi)型為innoDB類(lèi)型

mysql> alter table stu engine=innodb;

使用:

在PDO預(yù)處理的基礎(chǔ)上添加,如下格式:

try{
$m->beginTransaction();//開(kāi)啟事務(wù)處理
//PDO預(yù)處理以及執(zhí)行語(yǔ)句...
$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();//開(kāi)啟事務(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ǔ)充:再來(lái)一個(gè)php使用PDO的mysql事務(wù)處理與回滾操作實(shí)例分析

概述:

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

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

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

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

③.有異常就自動(dòng)拋出異常提示再回滾

④.開(kāi)啟自動(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è)是通過(guò)設(shè)置屬性方法進(jìn)行關(guān)閉自動(dòng)提交和上面的功能一樣
//$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, 0);
//開(kāi)啟異常處理
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}catch(PDOException $e){
echo "數(shù)據(jù)庫(kù)連接失?。?.$e->getMessage();
exit;
}
/*
* 事務(wù)處理
*
* 張三從李四那里買(mǎi)了一臺(tái) 2000 元的電腦
* 從張三帳號(hào)中扣出 2000元
* 向李四賬號(hào)中加入 2000元
* 從商品表中減少一臺(tái)電腦
* MyIsAM InnoDB
*/
try{
$pdo->beginTransaction();//開(kāi)啟事務(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

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫(kù)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》

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

您可能感興趣的文章:
  • php PDO異常處理詳解
  • PHP中PDO的錯(cuò)誤處理
  • php_pdo 預(yù)處理語(yǔ)句詳解
  • PHP中PDO的事務(wù)處理分析
  • php的PDO事務(wù)處理機(jī)制實(shí)例分析
  • php實(shí)現(xiàn)基于PDO的預(yù)處理示例
  • PHP使用pdo實(shí)現(xiàn)事務(wù)處理操作示例
  • PHP的異常處理類(lèi)Exception的使用及說(shuō)明
  • PHP如何拋出異常處理錯(cuò)誤
  • php實(shí)現(xiàn)的PDO異常處理操作分析

標(biāo)簽:宜春 工商登記 佛山 澳門(mén) 常德 深圳 宿遷 延安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP中PDO事務(wù)處理操作示例》,本文關(guān)鍵詞  PHP,中,PDO,事務(wù)處理,操作,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP中PDO事務(wù)處理操作示例》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于PHP中PDO事務(wù)處理操作示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章