mysql實現(xiàn)事務(wù)的提交與回滾的實例詳解
最近要對數(shù)據(jù)庫的數(shù)據(jù)進行一個定時遷移,為了防止在執(zhí)行過程sql語句因為某些原因報錯而導(dǎo)致數(shù)據(jù)轉(zhuǎn)移混亂,因此要對我們的腳本加以事務(wù)進行控制。
首先我們建一張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ù),但是為了防止插入中報錯,因此我要把插入語句控制在一個事務(wù)內(nèi)。
這時候,如果你查一下有些人的文章,許多時候會給出你這么一條答案。
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語句,并且這兩句也確實能實現(xiàn)提交或回滾。
然而這真的能達(dá)到我們的目的嗎?答案是否定的。
比如第一段,它是將你在事務(wù)中的sql語句無論對錯全部進行ROLLBACK。這樣絕對的回滾使得你的sql沒有任何意義了。
因此我們想要真正的控制好事務(wù),我的思路是對要執(zhí)行的sql進行異常檢測。如果sql沒有出現(xiàn)異常,COMMIT,如果捕獲到了異常,則ROLLBACK。
這時候,我們就需要建一個存儲過程來捕獲異常。執(zhí)行成功時進行COMMIT,sql執(zhí)行失敗時則進行ROLLBACK。
兩種思路可以達(dá)到我想要的效果。
第一種是對我們要執(zhí)行的sql進行異常捕獲,我們再定義一個變量t_error,當(dāng)捕獲到異常的時候,讓t_error=1。再對t_error進行條件判斷,如果t_error=1則進行ROLLBACK,否則進行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();
另一只則是第一種的簡化,即捕獲到異常直接進行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()
這樣,這兩個insert語句便真正的被控制在了一個事務(wù)內(nèi)了。
以上實例大家可以在本次測試一下,如果有其他補充和疑問可以直接聯(lián)系小編,感謝大家對腳本之家的支持。
相關(guān)文章
在linux命令下導(dǎo)出導(dǎo)入.sql文件的方法
這篇文章主要介紹了在linux命令下導(dǎo)出導(dǎo)入.sql文件的方法,具有很好的參考價值,給大家做個參考,跟隨小編過來看看吧2018-05-05Mysql?數(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-05percona-toolkit之pt-kill 殺掉mysql查詢或連接的方法
本文主要描述了percona-toolkit中pt-kill的 使用實例 ,及 一些重要參數(shù)的介紹,需要的朋友可以參考下2016-04-04Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢
這篇文章主要介紹了Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢,concat函數(shù)在SQL注入查詢中會有意想不到的作用,本文就起講解它的使用,需要的朋友可以參考下2015-04-04MySQL結(jié)合使用數(shù)據(jù)庫分析工具SchemaSpy的方法
這篇文章主要介紹了MySQL結(jié)合使用數(shù)據(jù)庫分析工具SchemaSpy的方法,需要的朋友可以參考下2015-06-06