程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php事務處理實例詳解

php事務處理實例詳解

編輯:關於PHP編程

       一、php事務處理概述:

      事務:是若干事件的集合

      事務處理:當所有事件執行成功,事務才執行;若有任何一個事件不能成功執行,事務的其它事件也不被執行。

      只要你的MySQL版本支持BDB或InnoDB表類型,那麼你的MySQL就具有事務處理的能力。這裡面,又以InnoDB表類型用的最多,雖然後來發生了諸如Oracle收購InnoDB等令MySQL不爽的事情,但是這類商業事件與技術無關,下面就以InnoDB表類型為例簡單說一下MySQL中的事務處理。

      二、php事務處理代碼:

      

      try{

      $pdo=new PDO("mysql:host=localhost;dbname=psp","root","");

      $pdo->exec("set names utf8");

      $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//設置異常處理模式

      $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);//關閉自動提交

      }catch(PDOException $e){

      echo "數據庫連接失敗";

      exit;

      }

      try{

      $age=10;

      $pdo->beginTransaction();//開始事務

      $affected_rows1=$pdo->exec("update kfry set k_age=k_age+{$age} where k_name='user1'");

      $affected_rows2=$pdo->exec("update kfry set k_age=k_age-{$age} where k_name='user2'");//隨意更改使之執行成功或失敗

      /* if($affected_rows1&&$affected_rows2)

      {

      $pdo->commit();

      echo "操作成功";

      }else{

      $pdo->rollback();

      } */

      if(!$affected_rows1)

      throw new PDOException("加入錯誤");

      if(!$affected_rows2)

      throw new PDOException("減少錯誤");

      echo "操作成功";

      $pdo->commit();//如果執行到此處前面兩個更新sql語句執行成功,整個事務執行成功

      }catch(PDOException $e){

      echo "操作失敗:".$e->getMessage();

      $pdo->rollback();//執行事務中的語句出了問題,整個事務全部撤銷

      }

      $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);

      //測試是否成功

      echo "n操作結果為:n";

      $sql="select * from kfry";

      $result=$pdo->query($sql);

      foreach($result as $v)

      {

      echo $v['k_name']." ".$v['k_age']."n";

      }

      ?>

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved