php實(shí)現(xiàn)基于pdo的事務(wù)處理方法示例
本文實(shí)例講述了php實(shí)現(xiàn)基于pdo的事務(wù)處理方法。分享給大家供大家參考,具體如下:
實(shí)例1:
try {} catch () {} 形式
<?php
$dsn = 'mysql:dbname=cheyun_cms;host=127.0.0.1';
$user = 'root';
$password = '111111';
//采用預(yù)處理+事務(wù)處理執(zhí)行SQL操作
//1.連接數(shù)據(jù)庫
try {
$pdo = new PDO($dsn, $user, $password);
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
die("數(shù)據(jù)庫連接失敗".$e->getMessage());
}
//2.執(zhí)行數(shù)據(jù)操作
try{
//開啟事物,此時(shí)會(huì)關(guān)閉自動(dòng)提交
$pdo->beginTransaction();
$sql = "insert into cy_log (logid, value, action, file) values (?, ?, ?, ?)";
$stmt = $pdo->prepare($sql);
//傳入?yún)?shù)
$stmt->execute(array(null,"test4","w",11));
$stmt->execute(array(null,"test5","w",11));
$stmt->execute(array(null,"test3","w",11));
//提交事物,并且 數(shù)據(jù)庫連接返回到自動(dòng)提交模式
$pdo->commit();
}catch(PDOException $e){
echo '執(zhí)行失敗'.$e->getMessage();
//如果數(shù)據(jù)庫被設(shè)置成自動(dòng)提交模式,rollback 在回滾事務(wù)之后將恢復(fù)自動(dòng)提交模式。
//包括 MySQL 在內(nèi)的一些數(shù)據(jù)庫, 當(dāng)在一個(gè)事務(wù)內(nèi)有類似刪除或創(chuàng)建數(shù)據(jù)表等 DLL 語句時(shí),會(huì)自動(dòng)導(dǎo)致一個(gè)隱式地提交。
//隱式地提交將無法回滾此事務(wù)范圍內(nèi)的任何更改。即 DDL 語句無法回滾
$pdo->rollback();
}
實(shí)例2:
if…else…形式
<?php
$dsn = 'mysql:dbname=cheyun_cms;host=127.0.0.1';
$user = 'root';
$password = '111111';
//采用預(yù)處理+事務(wù)處理執(zhí)行SQL操作
//1.連接數(shù)據(jù)庫
try {
$pdo = new PDO($dsn, $user, $password);
} catch (PDOException $e) {
die("數(shù)據(jù)庫連接失敗".$e->getMessage());
}
//2.執(zhí)行數(shù)據(jù)操作
//開啟事物
$pdo->beginTransaction();
$sql = "insert into cy_log (logid, value, action, file) values (?, ?, ?, ?)";
$stmt = $pdo->prepare($sql);
$datalist = array(
array(null,"test9","w",11),
array(null,"test10","w",11),
array(null,"test11","w",11)
);
//是否提交標(biāo)志位
$isCommit = true;
foreach($datalist as $data){
$stmt->execute($data);
if($stmt->errorCode()>0){
//回滾
$pdo->rollback();
$isCommit = false;
break;
}
}
if($isCommit){
//提交事物
$pdo->commit();
}
注意:
數(shù)據(jù)表需要 InnoDB 類型
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
解析php curl_setopt 函數(shù)的相關(guān)應(yīng)用及介紹
本篇文章是對(duì)php中的curl_setopt函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
PHP中array_merge和array相加的區(qū)別分析
今天處理一個(gè)這樣的問題:如何獲取字符鍵名相同值不同的兩個(gè)數(shù)組值集合,用array_merge和數(shù)組相加都不可行,讓我認(rèn)真比較了下PHP中array_merge和array相加的區(qū)別2013-06-06
php關(guān)鍵字僅替換一次的實(shí)現(xiàn)函數(shù)
這篇文章主要介紹了php實(shí)現(xiàn)每個(gè)關(guān)鍵字僅需要替換一次,有時(shí)一個(gè)項(xiàng)目里面涉及到批量替換關(guān)鍵字的問題,本文針對(duì)控制替換次數(shù)進(jìn)行研究,感興趣的小伙伴們可以參考一下2015-10-10
PHP連接SQL server數(shù)據(jù)庫測(cè)試腳本運(yùn)行實(shí)例
這篇文章主要介紹了PHP連接SQL server數(shù)據(jù)庫測(cè)試腳本運(yùn)行實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
php中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解
下面小編就為大家?guī)硪黄猵hp中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
PHP連接MySQL數(shù)據(jù)庫并以json格式輸出
PHP連接數(shù)據(jù)庫有多種方法,現(xiàn)介紹常用的MySQL數(shù)據(jù)庫連接方法,PHP連接MySQL也有兩種方式,一是面向?qū)ο?,二是面向過程方式,兩種方法稍有區(qū)別。下面通過代碼介紹兩種方法連接MySQL并以json格式輸出2018-05-05

