標籤:blog 使用 os io for cti ar div
1、用begin,rollback,commit來實現
begin 開始一個事務
rollback 交易回復
commit 事務確認
2、直接用set來改變mysql的自動認可模式
MYSQL預設是自動認可的,也就是你提交一個QUERY,它就直接執行!我們可以通過
set autocommit=0 禁止自動認可
set autocommit=1 開啟自動認可
來實現事務的處理。
但注意當你用 set autocommit=0 的時候,你以後所有的SQL都將做為交易處理,
直到你用commit確認或rollback結束,注意當你結束這個事務的同時也開啟了個新的事務!按第一種方法只將當前的作為一個事務!
個人推薦使用第一種方法!
[PHP]
function Tran( $sql ) {
$judge = 1;
mysql_query(‘begin‘);
foreach ($sql as $v) {
if ( !mysql_query($v) ) {
$judge = 0;
}
}
if ($judge == 0) {
mysql_query(‘rollback‘);
return false;
}
elseif ($judge == 1) {
mysql_query(‘commit‘);
return true;
}
}
[/PHP]
************************************************
<?php
$handler=mysql_connect("localhost","root","");
mysql_select_db("task");
mysql_query("SET AUTOCOMMIT=0");//設定為不自動認可,因為MYSQL預設立即執行
mysql_query("BEGIN");//開始事務定義
if(!mysql_query("insert into trans (id) values(‘2‘)"))
{
mysql_query("ROOLBACK");//判斷當執行失敗時復原
}
if(!mysql_query("insert into trans (id) values(‘4‘)"))
{
mysql_query("ROOLBACK");//判斷執行失敗復原
}
mysql_query("COMMIT");//執行事務
mysql_close($handler);
?>