事務處理:當所有事件執行成功,事務才執行;若有任何一個事件不能成功執行,事務的其它事件也不被執行。只要你的MySQL版本支持BDB或InnoDB表類型,那么你的MySQL就具有事務處理 " /> 亚洲一区二区三区中文字幕在线观看,国产精品一久久香蕉国产线看观看,精品久久久久久久人人人人传媒

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

php事務處理實例詳解

一、php事務處理概述:

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

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

二、php事務處理代碼:

<?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"; }?>

php技術php事務處理實例詳解,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 临洮县| 古蔺县| 临邑县| 安塞县| 宜城市| 阜阳市| 黄石市| 武清区| 武宁县| 桓台县| 溧水县| 池州市| 邵武市| 仙游县| 濮阳县| 黄浦区| 革吉县| 廉江市| 梅州市| 苏州市| 从化市| 天镇县| 会理县| 遂平县| 揭东县| 扎囊县| 启东市| 多伦县| 油尖旺区| 乐业县| 仁布县| 渑池县| 许昌县| 明光市| 东阳市| 府谷县| 什邡市| 南京市| 红原县| 洛浦县| 陆川县|