欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

最近要對數(shù)據(jù)庫的數(shù)據(jù)進行一個定時遷移,為了防止在執(zhí)行過程sql語句因為某些原因報錯而導致數(shù)據(jù)轉移混亂,因此要對我們的腳本加以事務進行控制。

公司主營業(yè)務:成都網(wǎng)站設計、成都網(wǎng)站建設、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出息縣免費做網(wǎng)站回饋大家。

首先我們建一張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ù),但是為了防止插入中報錯,因此我要把插入語句控制在一個事務內(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)提交或回滾。

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

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

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

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

兩種思路可以達到我想要的效果。

第一種是對我們要執(zhí)行的sql進行異常捕獲,我們再定義一個變量t_error,當捕獲到異常的時候,讓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語句便真正的被控制在了一個事務內(nèi)了。

以上實例大家可以在本次測試一下,如果有其他補充和疑問可以直接聯(lián)系小編,感謝大家對創(chuàng)新互聯(lián)的支持。

文章題目:mysql實現(xiàn)事務的提交與回滾的實例詳解
轉載注明:http://www.aaarwkj.com/article14/igsdde.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設計自適應網(wǎng)站、網(wǎng)站設計、網(wǎng)站排名、網(wǎng)站策劃微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設
神马视频一区二区在线观看| 麻豆国产av巨做国产剧情| 中文字幕乱码亚州精品一区| 亚洲中文字幕视频在看| 国产亚洲一区二区精品| 日本高清不卡在线一区二区| 四虎海外永久免费地址| 亚洲视频一区二区精品| 白嫩少妇情久久密月久久| 日本不卡免费一区二区视频| 亚洲性感美女男人的天堂| 日本人妻内射一区二区| 国产传媒视频网站在线观看| 亚洲国产日韩欧美在线播放| 尹人大香蕉在线视频| 久久精品国产亚洲av清纯| 韩国成人伦理片在线观看| 91亚洲精品久久久蜜桃网站| 国产男女爱猛视频在线| 五月婷婷六月丁香伊人网| 国产成人激情自拍视频在线观看| 成年人的黄色大片网站| 亚洲av日韩欧美精品| 亚洲综合久久国产一区二区| 91天美精东果冻麻豆| 国产精品av在线网站| 加勒比人妻一区二区三区| 亚洲人妻av一区二区三区| 日本精品在线一区二区| 日韩精品欧美视频久久| 亚洲色图综合在线观看| 国产精品网站在线观看不卡| 大胆丰满邻居少妇在线观看| 观看女性真实高潮的合集| 粉嫩国产av一区二区三区| 欧美黄色一区二区在线观看| 亚洲美女高潮久久久久久久久| av国语对白在线观看| 欧美国产日韩激情在线| 国产l精品国产亚洲区久久| 欧美日韩国产另类在线视频|