php交易處理執行個體詳解

來源:互聯網
上載者:User

   一、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";

  }

  ?>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.