|
一、php事務(wù)處理概述:
事務(wù):是若干事件的集合
事務(wù)處理:當(dāng)所有事件執(zhí)行成功,事務(wù)才執(zhí)行;若有任何一個(gè)事件不能成功執(zhí)行,事務(wù)的其它事件也不被執(zhí)行。
只要你的MySQL版本支持BDB或InnoDB表類(lèi)型,那么你的MySQL就具有事務(wù)處理的能力。這里面,又以InnoDB表類(lèi)型用的最多,雖然后來(lái)發(fā)生了諸如Oracle收購(gòu)InnoDB等令MySQL不爽的事情,但是這類(lèi)商業(yè)事件與技術(shù)無(wú)關(guān),下面就以InnoDB表類(lèi)型為例簡(jiǎn)單說(shuō)一下MySQL中的事務(wù)處理。
二、php事務(wù)處理代碼:
<?php try{ $pdo=new PDO("mysql:host=localhost;dbname=psp","root",""); $pdo->exec("set names utf8"); $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//設(shè)置異常處理模式 $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);//關(guān)閉自動(dòng)提交 }catch(PDOException $e){ echo "數(shù)據(jù)庫(kù)連接失敗"; exit; } try{ $age=10; $pdo->beginTransaction();//開(kāi)始事務(wù) $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'");//隨意更改使之執(zhí)行成功或失敗 /* if($affected_rows1&&$affected_rows2) { $pdo->commit(); echo "操作成功"; }else{ $pdo->rollback(); } */ if(!$affected_rows1) throw new PDOException("加入錯(cuò)誤"); if(!$affected_rows2) throw new PDOException("減少錯(cuò)誤"); echo "操作成功"; $pdo->commit();//如果執(zhí)行到此處前面兩個(gè)更新sql語(yǔ)句執(zhí)行成功,整個(gè)事務(wù)執(zhí)行成功 }catch(PDOException $e){ echo "操作失敗:".$e->getMessage(); $pdo->rollback();//執(zhí)行事務(wù)中的語(yǔ)句出了問(wèn)題,整個(gè)事務(wù)全部撤銷(xiāo) } $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1); //測(cè)試是否成功 echo "/n操作結(jié)果為:/n"; $sql="select * from kfry"; $result=$pdo->query($sql); foreach($result as $v) { echo $v['k_name']." ".$v['k_age']."/n"; }?>
php技術(shù):php事務(wù)處理實(shí)例詳解,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。