程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 基於mysql事務、視圖、存儲進程、觸發器的運用剖析

基於mysql事務、視圖、存儲進程、觸發器的運用剖析

編輯:MySQL綜合教程

基於mysql事務、視圖、存儲進程、觸發器的運用剖析。本站提示廣大學習愛好者:(基於mysql事務、視圖、存儲進程、觸發器的運用剖析)文章只能為提供參考,不一定能成為您想要的結果。以下是基於mysql事務、視圖、存儲進程、觸發器的運用剖析正文


一 ,mysql事務

MYSQL中只要INNODB類型的數據表能力支撐事務處置。

啟動事務有兩種辦法

(1) 用begin,rollback,commit來完成

begin  開端一個事務
rollback   事務回滾
commit    事務確認

(2)直接用set來轉變mysql的主動提交形式

set autocommit=0 制止主動提交
set autocommit=1 開啟主動提交

demo

header("Content-type:text/html;charset=utf-8");
mysql_pconnect("localhost","root","") or die("數據庫銜接掉敗");
mysql_select_db("test");
mysql_query("set names utf8");
//開啟一個事務
//mysql_query("BEGIN");
//mysql_query("START TRANSACTION");
//mysql_query("SET AUTOCOMMIT=1");//設置事務不主動提交 mysql默許是主動提交
mysql_query("SET AUTOCOMMIT=1");//開啟事務
$sql1 = "INSERT INTO `test`values ('2222','測試數據')";
$sql2 = "INSERT INTO `test` values ('111','sss','22')";//專程寫的毛病
$res1 = mysql_query($sql1);
$res2 = mysql_query($sql2);
if($res1 && $res2)
{
    mysql_query("COMMIT");
    echo "事務提交";
}else{
    mysql_query("ROLLBACK");
    echo "事務回滾";
}
mysql_query("END");

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved