国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-24 12:41:46
字體:
供稿:網(wǎng)友

最近要對數(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)系小編,感謝大家對武林網(wǎng)之家的支持。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 青州市| 盐城市| 连江县| 甘孜县| 凭祥市| 墨玉县| 东安县| 华亭县| 萨迦县| 武义县| 攀枝花市| 南投市| 花垣县| 宁强县| 金山区| 柳林县| 土默特左旗| 曲阳县| 敦煌市| 伊金霍洛旗| 大石桥市| 句容市| 稻城县| 星子县| 临洮县| 繁昌县| 桂阳县| 永胜县| 布拖县| 衡阳市| 弋阳县| 博爱县| 尼木县| 门头沟区| 陈巴尔虎旗| 兰州市| 温泉县| 辽宁省| 桐梓县| 敦煌市| 保山市|