欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php實(shí)現(xiàn)基于pdo的事務(wù)處理方法示例

 更新時(shí)間:2017年07月21日 11:12:17   作者:3wlog  
這篇文章主要介紹了php實(shí)現(xiàn)基于pdo的事務(wù)處理方法,結(jié)合實(shí)例形式分析了php使用pdo進(jìn)行事務(wù)操作的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(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ù)庫(kù)
try {
  $pdo = new PDO($dsn, $user, $password);
  $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
  die("數(shù)據(jù)庫(kù)連接失敗".$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ù)庫(kù)連接返回到自動(dòng)提交模式
  $pdo->commit();
}catch(PDOException $e){
  echo '執(zhí)行失敗'.$e->getMessage();
  //如果數(shù)據(jù)庫(kù)被設(shè)置成自動(dòng)提交模式,rollback 在回滾事務(wù)之后將恢復(fù)自動(dòng)提交模式。
  //包括 MySQL 在內(nèi)的一些數(shù)據(jù)庫(kù), 當(dāng)在一個(gè)事務(wù)內(nèi)有類似刪除或創(chuàng)建數(shù)據(jù)表等 DLL 語(yǔ)句時(shí),會(huì)自動(dòng)導(dǎo)致一個(gè)隱式地提交。
  //隱式地提交將無(wú)法回滾此事務(wù)范圍內(nèi)的任何更改。即 DDL 語(yǔ)句無(wú)法回滾
  $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ù)庫(kù)
try {
  $pdo = new PDO($dsn, $user, $password);
} catch (PDOException $e) {
  die("數(shù)據(jù)庫(kù)連接失敗".$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ù)庫(kù)技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫(kù)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總

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

相關(guān)文章

  • 什么是PHP文件?如何打開PHP文件?

    什么是PHP文件?如何打開PHP文件?

    什么是PHP文件?如何打開PHP文件?這篇文章主要為大家詳細(xì)介紹了解php文件以及如何打開php文件的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • php修改NetBeans默認(rèn)字體的大小

    php修改NetBeans默認(rèn)字體的大小

    在安裝完Netbeans后默認(rèn)的字體大小是11px。而在Windows下的宋體最小支持12px。所以字體為11px就已經(jīng)無(wú)法完整顯示了
    2013-07-07
  • 解析php curl_setopt 函數(shù)的相關(guān)應(yīng)用及介紹

    解析php curl_setopt 函數(shù)的相關(guān)應(yīng)用及介紹

    本篇文章是對(duì)php中的curl_setopt函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 二招解決php亂碼問(wèn)題

    二招解決php亂碼問(wèn)題

    PHP的亂碼問(wèn)題已經(jīng)說(shuō)了N+1遍了,但還是經(jīng)??吹叫率植恢涝撊绾谓鉀Qphp亂碼問(wèn)題,在此本人再重新給總結(jié)一下,希望對(duì)新手有點(diǎn)幫助
    2012-03-03
  • PHP中array_merge和array相加的區(qū)別分析

    PHP中array_merge和array相加的區(qū)別分析

    今天處理一個(gè)這樣的問(wèn)題:如何獲取字符鍵名相同值不同的兩個(gè)數(shù)組值集合,用array_merge和數(shù)組相加都不可行,讓我認(rèn)真比較了下PHP中array_merge和array相加的區(qū)別
    2013-06-06
  • PHP提取字符串中的圖片地址[正則表達(dá)式]

    PHP提取字符串中的圖片地址[正則表達(dá)式]

    PHP提取字符串中的圖片地址,實(shí)際就是利用正則表達(dá)式匹配圖片地址,需要的朋友參考下。
    2011-11-11
  • php關(guān)鍵字僅替換一次的實(shí)現(xiàn)函數(shù)

    php關(guān)鍵字僅替換一次的實(shí)現(xiàn)函數(shù)

    這篇文章主要介紹了php實(shí)現(xiàn)每個(gè)關(guān)鍵字僅需要替換一次,有時(shí)一個(gè)項(xiàng)目里面涉及到批量替換關(guān)鍵字的問(wèn)題,本文針對(duì)控制替換次數(shù)進(jìn)行研究,感興趣的小伙伴們可以參考一下
    2015-10-10
  • PHP連接SQL server數(shù)據(jù)庫(kù)測(cè)試腳本運(yùn)行實(shí)例

    PHP連接SQL server數(shù)據(jù)庫(kù)測(cè)試腳本運(yùn)行實(shí)例

    這篇文章主要介紹了PHP連接SQL server數(shù)據(jù)庫(kù)測(cè)試腳本運(yùn)行實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • php中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解

    php中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解

    下面小編就為大家?guī)?lái)一篇php中的單引號(hào)、雙引號(hào)和轉(zhuǎn)義字符詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • PHP連接MySQL數(shù)據(jù)庫(kù)并以json格式輸出

    PHP連接MySQL數(shù)據(jù)庫(kù)并以json格式輸出

    PHP連接數(shù)據(jù)庫(kù)有多種方法,現(xiàn)介紹常用的MySQL數(shù)據(jù)庫(kù)連接方法,PHP連接MySQL也有兩種方式,一是面向?qū)ο?,二是面向過(guò)程方式,兩種方法稍有區(qū)別。下面通過(guò)代碼介紹兩種方法連接MySQL并以json格式輸出
    2018-05-05

最新評(píng)論