本文目錄一覽:
- 1、請問在php中如何控制多表事務?
- 2、php如何使用事務和存儲過程
- 3、php+access如何實現事務處理?
- 4、php 怎麼使用Mysql事務實例代碼
- 5、PHP 中mysql如何實現事務提交
- 6、php 多張表怎樣使用事務
請問在php中如何控制多表事務?
php框架中多表事務操作實例,參考如下:
function makeAcquire($nUsers,$nAwards)
{
//更新資料庫
$tranDb = new Model();
$tranDb-startTrans();
for($i = 0; $i sizeof($nUsers); $i++)
{
//更新表Acquire
$flagAc = $tranDb-table(‘Acquire’)-add($acquire);
//更新表Users
$where = array(‘u_id’=$nUsers[$i][‘u_id’]);
$flagU = $tranDb-table(‘Users’)-where($where)-setInc(‘u_man_count’,1);
//更新表Award
$where = array(‘a_id’=$nAwards[$i][‘a_id’]);
$flagA = $tranDb-table(‘Award’)-where($where)-setDec(‘a_count’,1);
}
if($flagAc $flagU $flagA)
{
$tranDb-commit();
}
else
{
$tranDb-rollback();
}
}
php如何使用事務和存儲過程
去掉extention=php_mysqli前的分號 重啟apache
mysqli_query 可執行事務和存儲過程~
php+access如何實現事務處理?
PHP與MYSQL事務處理
/*
MYSQL的事務處理主要有兩種方法。
1、用begin,rollback,commit來實現
begin 開始一個事務
rollback 事務回滾
commit 事務確認
2、直接用set來改變mysql的自動提交模式
MYSQL默認是自動提交的,也就是你提交一個QUERY,它就直接執行!我們可以通過
set autocommit=0 禁止自動提交
set autocommit=1 開啟自動提交
來實現事務的處理。
當你用 set autocommit=0 的時候,你以後所有的SQL都將做為事務處理,直到你用commit確認或rollback結束。
注意當你結束這個事務的同時也開啟了個新的事務!按第一種方法只將當前的作為一個事務!
個人推薦使用第一種方法!
MYSQL中只有INNODB和BDB類型的數據表才能支持事務處理!其他的類型是不支持的!
***:一般MYSQL資料庫默認的引擎是MyISAM,這種引擎不支持事務!如果要讓MYSQL支持事務,可以自己手動修改:
方法如下:1.修改c:\appserv\mysql\my.ini文件,找到skip-InnoDB,在前面加上#,後保存文件。
2.在運行中輸入:services.msc,重啟mysql服務。
3.到phpmyadmin中,mysql-show engines;(或執行mysql-show variables like ‘have_%’; ),查看InnoDB為YES,即表示資料庫支持InnoDB了。
也就說明支持事務transaction了。
4.在創建表時,就可以為Storage Engine選擇InnoDB引擎了。如果是以前創建的表,可以使用mysql-alter table table_name type=InnoDB;
或 mysql-alter table table_name engine=InnoDB;來改變數據表的引擎以支持事務。
*/
/*************** transaction–1 ***************/
$conn = mysql_connect(‘localhost’,’root’,’root’) or die (“數據連接錯誤!!!”);
mysql_select_db(‘test’,$conn);
mysql_query(“set names ‘GBK'”); //使用GBK中文編碼;
//開始一個事務
mysql_query(“BEGIN”); //或者mysql_query(“START TRANSACTION”);
$sql = “INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, ‘test1’, ‘0’)”;
$sql2 = “INSERT INTO `user` (`did`, `username`, `sex`) VALUES (NULL, ‘test1’, ‘0’)”;//這條我故意寫錯
$res = mysql_query($sql);
$res1 = mysql_query($sql2);
if($res $res1){
mysql_query(“COMMIT”);
echo ‘提交成功。’;
}else{
mysql_query(“ROLLBACK”);
echo ‘數據回滾。’;
}
mysql_query(“END”);
/**************** transaction–2 *******************/
/*方法二*/
mysql_query(“SET AUTOCOMMIT=0”); //設置mysql不自動提交,需自行用commit語句提交
$sql = “INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, ‘test1’, ‘0’)”;
$sql2 = “INSERT INTO `user` (`did`, `username`, `sex`) VALUES (NULL, ‘test1’, ‘0’)”;//這條我故意寫錯
$res = mysql_query($sql);
$res1 = mysql_query($sql2);
if($res $res1){
mysql_query(“COMMIT”);
echo ‘提交成功。’;
}else{
mysql_query(“ROLLBACK”);
echo ‘數據回滾。’;
}
mysql_query(“END”); //事務處理完時別忘記mysql_query(“SET AUTOCOMMIT=1”);自動提交
/******************對於不支持事務的MyISAM引擎資料庫可以使用表鎖定的方法:********************/
//MyISAM InnoDB 都支持,
/*
LOCK TABLES可以鎖定用於當前線程的表。如果表被其它線程鎖定,則造成堵塞,直到可以獲取所有鎖定為止。
UNLOCK TABLES可以釋放被當前線程保持的任何鎖定。當線程發布另一個LOCK TABLES時,或當與伺服器的連接被關閉時,所有由當前線程鎖定的表被隱含地解鎖。
*/
mysql_query(“LOCK TABLES `user` WRITE”);//鎖住`user`表
$sql = “INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, ‘test1’, ‘0’)”;
$res = mysql_query($sql);
if($res){
echo ‘提交成功。!’;
}else{
echo ‘失敗!’;
}
mysql_query(“UNLOCK TABLES”);//解除鎖定
MyISAM 是MySQL中默認的存儲引擎,一般來說不是有太多人關心這個東西。決定使用什麼樣的存儲引擎是一個很tricky的事情,但是還是值我們去研究一下,這裡的文章只考慮 MyISAM 和InnoDB這兩個,因為這兩個是最常見的。
php 怎麼使用Mysql事務實例代碼
$con=mysqli_connect(‘localhost’,’root’,’123456′,’test’);
if (!$con){
exit(“連接錯誤”);
}
mysqli_set_charset($con,’utf8′);
mysqli_query($con,”BEGIN”);//開啟事務
$sql = “sql語句1”;
$sql2 = “sql語句2”;
$res = mysqli_query($con,$sql);
$res1 = mysqli_query($con,$sql2);
if($res $res1){
mysqli_query($con,”COMMIT”);//提交事務
echo ‘提交成功。’;
}else{
mysqli_query($con,”ROLLBACK”);//事務回滾
echo ‘數據回滾。’;
}
mysqli_query($con,”END”);
PHP 中mysql如何實現事務提交
事務就是指對資料庫的多次修改,要麼全部成功,要麼全部失敗,不能出現部分修改成功,部分修改失敗的情況。
PHP下操作mysql資料庫要實現事務提交,需注意以下方面:
1, 資料庫表存儲引擎類型設置為innoDB。默認的mysql表採用MYISAM引擎,是不支持事務的,因此要採用以下語句變更:
mysql alter table 『table_name』 engine=innodb;
2,PDO對象設置要設置errmode為Exception,否則第16行SQL執行出錯,語句也不會跳到catch段去rollback, 而是繼續向下執行直到commit。
php 多張表怎樣使用事務
具體代碼如下:
?php
$ch = curl_init();
$timeout = 5;
curl_setopt ($ch, CURLOPT_URL, ”);
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
$file_contents = curl_exec($ch);
curl_close($ch);
echo $file_contents;
?
PHP 獨特的語法混合了C、Java、Perl以及PHP自創的語法。
它可以比CGI或者Perl更快速地執行動態網頁。用PHP做出的動態頁面與其他的編程語言相比,PHP是將程序嵌入到HTML(標準通用標記語言下的一個應用)文檔中去執行,
執行效率比完全生成HTML標記的CGI要高許多;
PHP還可以執行編譯後代碼,編譯可以達到加密和優化代碼運行,使代碼運行更快。
原創文章,作者:GYUUU,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/324426.html