事務處理:當所有事件執行成功,事務才執行;若有任何一個事件不能成功執行,事務的其它事件也不被執行。只要你的MySQL版本支持BDB或InnoDB表類型,那么你的MySQL就具有事務處理 " /> 成人免费短视频,久久成人18免费观看,蜜桃视频成人

色尼玛亚洲综合影院,亚洲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事務處理實例詳解,轉載需保留來源!

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

主站蜘蛛池模板: 壤塘县| 探索| 木里| 盈江县| 耒阳市| 博湖县| 平阴县| 元阳县| 武宁县| 樟树市| 观塘区| 白山市| 通许县| 搜索| 南部县| 阿尔山市| 五寨县| 汤阴县| 南漳县| 永泰县| 马公市| 金塔县| 辉南县| 闸北区| 丰顺县| 江津市| 阳新县| 鱼台县| 比如县| 定结县| 淮安市| 鄄城县| 虎林市| 南充市| 罗平县| 隆化县| 濉溪县| 肥城市| 孝感市| 那曲县| 钟祥市|