亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

本文實例講述了php實現(xiàn)基于pdo的事務(wù)處理方法。分享給大家供大家參考,具體如下:

實例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{
  //開啟事物,此時會關(guān)閉自動提交
  $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ù)庫連接返回到自動提交模式
  $pdo->commit();
}catch(PDOException $e){
  echo '執(zhí)行失敗'.$e->getMessage();
  //如果數(shù)據(jù)庫被設(shè)置成自動提交模式,rollback 在回滾事務(wù)之后將恢復(fù)自動提交模式。
  //包括 MySQL 在內(nèi)的一些數(shù)據(jù)庫, 當(dāng)在一個事務(wù)內(nèi)有類似刪除或創(chuàng)建數(shù)據(jù)表等 DLL 語句時,會自動導(dǎo)致一個隱式地提交。
  //隱式地提交將無法回滾此事務(wù)范圍內(nèi)的任何更改。即 DDL 語句無法回滾
  $pdo->rollback();
}

實例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è)計技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

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

相關(guān)文章

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

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

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

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

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

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

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

    二招解決php亂碼問題

    PHP的亂碼問題已經(jīng)說了N+1遍了,但還是經(jīng)常看到新手不知道該如何解決php亂碼問題,在此本人再重新給總結(jié)一下,希望對新手有點幫助
    2012-03-03
  • PHP中array_merge和array相加的區(qū)別分析

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

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

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

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

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

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

    PHP連接SQL server數(shù)據(jù)庫測試腳本運行實例

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

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

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

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

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

最新評論