欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例詳解

 更新時(shí)間:2020年01月05日 14:51:49   作者:微笑點(diǎn)燃希望  
在本篇文章中我們給大家分享一篇關(guān)于mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例內(nèi)容,有需要的朋友們可以參考學(xué)習(xí)下。

最近要對數(shù)據(jù)庫的數(shù)據(jù)進(jìn)行一個(gè)定時(shí)遷移,為了防止在執(zhí)行過程sql語句因?yàn)槟承┰驁?bào)錯(cuò)而導(dǎo)致數(shù)據(jù)轉(zhuǎn)移混亂,因此要對我們的腳本加以事務(wù)進(jìn)行控制。

首先我們建一張tran_test表

CREATE TABLE tran_test( 
f1 VARCHAR(10) NOT NULL, 
f2 INT(1) DEFAULT NULL, 
PRIMARY KEY (f1) 
)ENGINE=INNODB CHARSET=utf8

我想對tran_test插入兩條數(shù)據(jù),但是為了防止插入中報(bào)錯(cuò),因此我要把插入語句控制在一個(gè)事務(wù)內(nèi)。

這時(shí)候,如果你查一下有些人的文章,許多時(shí)候會給出你這么一條答案。

START TRANSACTION;  
INSERT INTO tran_test VALUES('A',1); 
INSERT INTO tran_test VALUES('B',2); 
ROLLBACK;

START TRANSACTION;  
INSERT INTO tran_test VALUES('A',1); 
INSERT INTO tran_test VALUES('B',2); 
COMMIT;

看上去很簡單的sql語句,并且這兩句也確實(shí)能實(shí)現(xiàn)提交或回滾。

然而這真的能達(dá)到我們的目的嗎?答案是否定的。

比如第一段,它是將你在事務(wù)中的sql語句無論對錯(cuò)全部進(jìn)行ROLLBACK。這樣絕對的回滾使得你的sql沒有任何意義了。

因此我們想要真正的控制好事務(wù),我的思路是對要執(zhí)行的sql進(jìn)行異常檢測。如果sql沒有出現(xiàn)異常,COMMIT,如果捕獲到了異常,則ROLLBACK。

這時(shí)候,我們就需要建一個(gè)存儲過程來捕獲異常。執(zhí)行成功時(shí)進(jìn)行COMMIT,sql執(zhí)行失敗時(shí)則進(jìn)行ROLLBACK。

兩種思路可以達(dá)到我想要的效果。

第一種是對我們要執(zhí)行的sql進(jìn)行異常捕獲,我們再定義一個(gè)變量t_error,當(dāng)捕獲到異常的時(shí)候,讓t_error=1。再對t_error進(jìn)行條件判斷,如果t_error=1則進(jìn)行ROLLBACK,否則進(jìn)行COMMIT。

DROP PROCEDURE IF EXISTS t_test; 
DELIMITER // 
CREATE PROCEDURE t_test() 
 BEGIN 
  DECLARE t_error INTEGER; 
  DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error = 1; 
  START TRANSACTION; 
     INSERT INTO tran_test VALUES('A',1); 
   INSERT INTO tran_test VALUES('B',2); 
     IF t_error = 1 THEN 
       ROLLBACK; 
     ELSE 
       COMMIT; 
     END IF; 
END// 
CALL t_test();

另一只則是第一種的簡化,即捕獲到異常直接進(jìn)行ROLLBACK,如果沒捕獲到異常,直接COMMIT

DROP PROCEDURE IF EXISTS t_test; 
DELIMITER // 
CREATE PROCEDURE t_test() 
BEGIN 
DECLARE EXIT HANDLER FOR SQLEXCEPTION ROLLBACK; 
START TRANSACTION; 
INSERT INTO tran_test VALUES('A',1); 
INSERT INTO tran_test VALUES('B',2); 
COMMIT; 
END// 
CALL t_test()

這樣,這兩個(gè)insert語句便真正的被控制在了一個(gè)事務(wù)內(nèi)了。

以上實(shí)例大家可以在本次測試一下,如果有其他補(bǔ)充和疑問可以直接聯(lián)系小編,感謝大家對腳本之家的支持。

相關(guān)文章

  • 在linux命令下導(dǎo)出導(dǎo)入.sql文件的方法

    在linux命令下導(dǎo)出導(dǎo)入.sql文件的方法

    這篇文章主要介紹了在linux命令下導(dǎo)出導(dǎo)入.sql文件的方法,具有很好的參考價(jià)值,給大家做個(gè)參考,跟隨小編過來看看吧
    2018-05-05
  • MySQL操作并使用Python進(jìn)行連接

    MySQL操作并使用Python進(jìn)行連接

    這篇文章主要介紹了MySQL操作并使用Python進(jìn)行連接,文章通過設(shè)置外鍵進(jìn)行表與表的相連,且外鍵必須是其他表的主鍵展開詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-06-06
  • 經(jīng)測試最好用的mysql密碼忘記的解決方法

    經(jīng)測試最好用的mysql密碼忘記的解決方法

    經(jīng)測試最好用的mysql密碼忘記的解決方法...
    2007-06-06
  • Mysql?數(shù)據(jù)庫結(jié)構(gòu)及索引類型

    Mysql?數(shù)據(jù)庫結(jié)構(gòu)及索引類型

    這篇文章主要介紹了Mysql?數(shù)據(jù)庫結(jié)構(gòu)及索引類型,數(shù)據(jù)庫索引是?mysql?數(shù)據(jù)庫中重要的組成部分,是數(shù)據(jù)庫查詢數(shù)據(jù)速度提升的關(guān)鍵,本文將介紹數(shù)據(jù)庫索引的一些內(nèi)容,下文更多相關(guān)內(nèi)容,需要的小伙伴可以參考一下
    2022-05-05
  • percona-toolkit之pt-kill 殺掉mysql查詢或連接的方法

    percona-toolkit之pt-kill 殺掉mysql查詢或連接的方法

    本文主要描述了percona-toolkit中pt-kill的 使用實(shí)例 ,及 一些重要參數(shù)的介紹,需要的朋友可以參考下
    2016-04-04
  • Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢

    Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢

    這篇文章主要介紹了Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢,concat函數(shù)在SQL注入查詢中會有意想不到的作用,本文就起講解它的使用,需要的朋友可以參考下
    2015-04-04
  • MySQL結(jié)合使用數(shù)據(jù)庫分析工具SchemaSpy的方法

    MySQL結(jié)合使用數(shù)據(jù)庫分析工具SchemaSpy的方法

    這篇文章主要介紹了MySQL結(jié)合使用數(shù)據(jù)庫分析工具SchemaSpy的方法,需要的朋友可以參考下
    2015-06-06
  • MySQL特殊函數(shù)使用技巧梳理

    MySQL特殊函數(shù)使用技巧梳理

    MySQL提供了各種特殊函數(shù),它們可以幫助管理者查詢復(fù)雜的數(shù)據(jù),資料庫包括字符串函數(shù),數(shù)學(xué)函數(shù),日期函數(shù),程序函數(shù)等,下面這篇文章主要給大家介紹了關(guān)于MySQL特殊函數(shù)使用技巧的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 在MySQL concat里面使用多個(gè)單引號,三引號的問題

    在MySQL concat里面使用多個(gè)單引號,三引號的問題

    今天小編就為大家分享一篇在MySQL concat里面使用多個(gè)單引號,三引號的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • mysql 主從服務(wù)器的簡單配置

    mysql 主從服務(wù)器的簡單配置

    首先呢,需要有兩個(gè)mysql服務(wù)器。如果做測試的話可以在同一臺機(jī)器上裝兩個(gè)mysql服務(wù)程序,注意要兩個(gè)運(yùn)行程序的端口不能一樣。我用的是一個(gè)是默認(rèn)的3306,從服務(wù)器用的是3307端口。
    2009-05-05

最新評論