天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP mysql與mysqli事務使用說明 分享

mysqli封裝了諸如事務等一些高級操作,同時封裝了DB操作過程中的很多可用的方法。

應用比較多的地方是 mysqli的事務。

比如下面的示例:

復制代碼 代碼如下:

$mysqli = new mysqli('localhost','root','','DB_Lib2Test');
$mysqli->autocommit(false);//開始事物
$mysqli->query($sql1);
$mysqli->query($sql2);
if(!$mysqli->errno){
  $mysqli->commit();
  echo 'ok';
}else{
 echo 'err';
  $mysqli->rollback();
}

php中,mysqli 已經很好的封裝了mysql事務的相關操作。如下示例:

復制代碼 代碼如下:
$sql1 = "update User set ScoreCount = ScoreCount +10 where ID= '123456'";
$sql2 = "update ScoreDetail  set FScore = 300 where ID= '123456'";
$sql3 = "insert into  ScoreDetail ID,Score) values ('123456',60)";

$mysqli = new mysqli('localhost','root','','DB_Lib2Test');
$mysqli->autocommit(false); // 開始事務
$mysqli->query($sql1);
$mysqli->query($sql2);
if (!$mysqli->errno) {
 $mysqli->commit();
 echo 'ok';
} else {
 echo 'err';
 $mysqli->rollback();
}

在這里,我們再使用 php mysql 系列函數執行事務。

復制代碼 代碼如下:
$sql1 = "update User set ScoreCount = ScoreCount +10 where ID= '123456'";
$sql2 = "update ScoreDetail  set FScore = 300 where ID= '123456'";
$sql3 = "insert into  ScoreDetail ID,Score) values ('123456',60)";

$conn = mysql_connect('localhost','root','');
mysql_select_db('DB_Lib2Test');
mysql_query('start transaction');
//mysql_query('SET autocommit=0');

mysql_query($sql1);
mysql_query($sql2);
if (mysql_errno()) {
 mysql_query('rollback');
 echo 'err';
} else {
 mysql_query('commit');
 echo 'ok';
}

// mysql_query('SET autocommit=1');
// mysql_query($sql3);

在這里要注意,

MyISAM:不支持事務,用于只讀程序提高性能
InnoDB:支持ACID事務、行級鎖、并發
Berkeley DB:支持事務
還有一點要注意:MySQL默認的行為是在每條SQL語句執行后執行一個COMMIT語句,從而有效的將每條語句獨立為一個事務。

但往往,我們需要在使用事務的時候,是需要執行多條sql語句的。這就需要我們手動設置MySQL的autocommit屬性為0,默認為1。

同時,使用START TRANSACTION語句顯式的打開一個事務 。如上面的示例。

如果不這樣做,會有什么結果呢?

我們將上面第二段代碼中 //mysql_query(‘SET autocommit=0′); 和 // mysql_query($sql3); 注釋去掉,然后執行。

此時,mysql_query($sql3) 執行就不會insert到數據庫中。

如果我們將 // mysql_query(‘SET autocommit=1′); 本句注釋去掉,那么mysql_query($sql3); 就會執行成功。

通常COMMIT或ROLLBACK語句執行時才完成一個事務,但是有些DDL語句等會隱式觸發COMMIT。

比如下列語句

ALTER FUNCTION
ALTER PROCEDURE
ALTER TABLE
BEGIN
CREATE DATABASE
CREATE FUNCTION
CREATE INDEX
CREATE PROCEDURE
CREATE TABLE
DROP DATABASE
DROP FUNCTION
DROP INDEX
DROP PROCEDURE
DROP TABLE
UNLOCK TABLES
LOAD MASTER DATA
LOCK TABLES
RENAME TABLE
TRUNCATE TABLE
SET AUTOCOMMIT=1
START TRANSACTION

我們再來舉個例子看下。

復制代碼 代碼如下:
$sql1 = 'create table ScoreDetail_new(id int)';
$sql2 = 'rename table ScoreDetail to ScoreDetail_bak';
$sql3  = 'rename table ScoreDetail_new to ScoreDetail';

$mysqli = new mysqli('localhost','root','','DB_Lib2Test');
$mysqli->autocommit(false);//開始事物
$mysqli->query($sql1);
$mysqli->query($sql2);
$mysqli->query($sql3);
if (!$mysqli->errno) {
 $mysqli->commit();
 echo 'ok';
} else {
 echo 'err';
 $mysqli->rollback();
}

上面的示例中,假如$sql2執行出錯了,$sql1照樣會執行的。為什么呢?

因為rename在執行的時候,mysql默認會先執行commit,再執行rename。

注意

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了。

php技術PHP mysql與mysqli事務使用說明 分享,轉載需保留來源!

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

主站蜘蛛池模板: 九九99亚洲精品久久久久 | 国产精品久久精品视 | 亚洲爆乳无码精品AAA片蜜桃 | 中文无码熟妇人妻AV在线 | 欧美双拳极限扩张 | 秀婷程仪公欲息肉婷在线观看 | 亚洲色欲色欲综合网站 | 日本久久精品视频 | 99精品欧美一区二区三区美图 | 某上海少妇3P黑人完整版BD | 韩国成人理伦片免费播放 | 日久精品不卡一区二区 | 在线精品视频成人网 | 国产交换丝雨巅峰 | a免费在线观看视频 | 无人区乱码1区2区3区网站 | 麻豆成人久久精品二区三区网站 | 一起洗澡的老师免费播放 | 中文无码字慕在线观看 | 无人区日本电影在线观看 | 月夜直播免费观看全集 | 亚洲无AV在线中文字幕 | 夜色福利院在线观看免费 | 草莓视频app深夜福利 | 亚洲欧美一区二区三区四区 | 久久精品国产色蜜蜜麻豆国语版 | 国产产乱码一二三区别免费 | 99久久国内精品成人免费 | 手机看片一区二区 | 色偷偷亚洲男人天堂 | 最近免费中文字幕MV在线视频3 | 大学生第一次破女在线观看 | nxgx69日本护士 | JAVAPARSER丰满白老师 | 亚洲无遮挡 | 伊人网伊人网 | 久久无码AV亚洲精品色午夜麻豆 | 一级做a爰片久久免费 | 免费亚洲视频在线观看 | JAPANRCEP老熟妇乱子伦视频 | 亚洲乱色视频在线观看 |