php結(jié)合mysql與mysqli擴(kuò)展處理事務(wù)的方法
本文實(shí)例講述了php結(jié)合mysql與mysqli擴(kuò)展處理事務(wù)的方法。分享給大家供大家參考,具體如下:
以下只是展示如何應(yīng)用,具體用的時(shí)候要加上判斷,如果都執(zhí)行成功則提交,否則回滾
看前先分清mysqli與mysql擴(kuò)展是不一樣的
mysqli擴(kuò)展處理事物:
$mysqli=new mysqli('localhost','root','123456','test'); $mysqli->autocommit(false);//開始事物 $query="update a set money=money+30 where a_id='1'"; $mysqli->query($query); $query="update b set money=money-30 where b_id='1'"; $mysqli->query($query); //$mysqli->rollback();//回滾 $mysqli->commit(); //提交事物 $mysqli->autocommit(true);//不使用事物
mysql擴(kuò)展處理事物:
<?php mysql_connect('localhost','root','123456'); mysql_select_db('test'); mysql_query('SET AUTOCOMMIT=0'); //不自動(dòng)提交 mysql_query('BEGIN'); //開始事務(wù) $query="UPDATE a SET money = money +30 WHERE a_id =1"; mysql_query($query); $query="UPDATE b SET money = money -30 WHERE b_id =1"; mysql_query($query); mysql_query('COMMIT'); //提交 //mysql_query('ROLLBACK'); //回滾 mysql_query('SET AUTOCOMMIT=1'); //打開自動(dòng)提交 ?>
對(duì)mysql擴(kuò)展處理事務(wù)的說(shuō)明,原文可參考本站:
http://www.dbjr.com.cn/article/50944.htm
MYSQL的事務(wù)處理主要有兩種方法。
1、用begin,rollback,commit來(lái)實(shí)現(xiàn)
begin 開始一個(gè)事務(wù)
rollback 事務(wù)回滾
commit 事務(wù)確認(rèn)
2、直接用set來(lái)改變mysql的自動(dòng)提交模式
MYSQL默認(rèn)是自動(dòng)提交的,也就是你提交一個(gè)QUERY,它就直接執(zhí)行!我們可以通過(guò):
set autocommit=0 禁止自動(dòng)提交
set autocommit=1 開啟自動(dòng)提交
來(lái)實(shí)現(xiàn)事務(wù)的處理。
但注意當(dāng)你用 set autocommit=0 的時(shí)候,你以后所有的SQL都將做為事務(wù)處理,直到你用commit確認(rèn)或rollback結(jié)束,注意當(dāng)你結(jié)束這個(gè)事務(wù)的同時(shí)也開啟了個(gè)新的事務(wù)!按第一種方法只將當(dāng)前的作為一個(gè)事務(wù)!
個(gè)人推薦使用第一種方法!
MYSQL中只有INNODB和BDB類型的數(shù)據(jù)表才能支持事務(wù)處理!其他的類型是不支持的?。ㄇ杏洠。?/span>
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+mysqli數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php 大數(shù)據(jù)量及海量數(shù)據(jù)處理算法總結(jié)
大數(shù)據(jù)量的問(wèn)題是很多面試筆試中經(jīng)常出現(xiàn)的問(wèn)題,比如baidu google 騰訊 這樣的一些涉及到海量數(shù)據(jù)的公司經(jīng)常會(huì)問(wèn)到2011-05-05PHP+原生態(tài)ajax實(shí)現(xiàn)的省市聯(lián)動(dòng)功能詳解
這篇文章主要介紹了PHP+原生態(tài)ajax實(shí)現(xiàn)的省市聯(lián)動(dòng)功能,較為詳細(xì)的分析了ajax交互的原理、實(shí)現(xiàn)方法以及php結(jié)合ajax實(shí)現(xiàn)省市聯(lián)動(dòng)下拉菜單功能的相關(guān)操作技巧,需要的朋友可以參考下2017-08-08PHP一些常用的正則表達(dá)式字符的一些轉(zhuǎn)換
一些前臺(tái)的正則運(yùn)行,你可以修改下成為php的2008-07-07PHP創(chuàng)建單例后臺(tái)進(jìn)程的方法示例
這篇文章主要介紹了PHP創(chuàng)建單例后臺(tái)進(jìn)程的方法,涉及php針對(duì)進(jìn)程的啟動(dòng)、創(chuàng)建、判斷、停止等相關(guān)操作技巧,需要的朋友可以參考下2017-05-05深入理解用mysql_fetch_row()以數(shù)組的形式返回查詢結(jié)果
本篇文章是對(duì)使用mysql_fetch_row()以數(shù)組的形式返回查詢結(jié)果進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP 數(shù)組遍歷方法大全(foreach,list,each)
php下最靈活的東西都是數(shù)組,很多數(shù)據(jù)都是通過(guò)數(shù)組的方式顯示,這里整理下數(shù)組的遍歷方法,大家可以根據(jù)需要選用。2010-06-06php 使用file_get_contents讀取大文件的方法
本文介紹了在php中使用file_get_contents函數(shù)讀取大文件的方法,并附上了示例以及使用小技巧,非常的實(shí)用,這里推薦給大家2014-11-11