MySQL中怎么實現(xiàn)事物回滾

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)MySQL中怎么實現(xiàn)事物回滾,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

陽東網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。

事物的概念:

事物由一個單獨單元的一個或多個sql語句組成,如果其中一個語句不能完成,整個單元就會回滾,所有影響到的數(shù)據(jù)將返回到事物開始以前的狀態(tài)。因而,只有事物中的所有語句都成功執(zhí)行才能說明這個事物被成功的執(zhí)行。

這句話的本身沒有什么問題,但是請看下面的案例

mysql事務(wù)中有兩條insert語句,其中第二條語句是錯誤的,在運行完事務(wù)后,第一條仍然插進去了,代碼如下。

//創(chuàng)建表:CREATE TABLE `test_tab` (`f1`  int(11) NOT NULL ,`f2`  varchar(11)  DEFAULT NULL ,PRIMARY KEY (`f1`))ENGINE=InnoDB
//執(zhí)行事務(wù):START TRANSACTION;INSERT INTO test_tab VALUES    (1, '2');INSERT INTO test_tab VALUES    (1, '3');COMMIT;

 一開始認(rèn)為只要把事務(wù)寫出來,最后用commit提交一下,數(shù)據(jù)庫會自動判斷這些語句是否全執(zhí)行成功,如果成功則把所有的數(shù)據(jù)插入到數(shù)據(jù)庫,如果有一條失敗就自動回滾至原始狀態(tài)!顯然我認(rèn)為錯了。

[SQL]START TRANSACTION;受影響的行: 0時間: 0.000s
[SQL]INSERT INTO test_tab VALUES (1, '2');受影響的行: 1時間: 0.001s
[SQL]INSERT INTO test_tab VALUES (1, '3');[Err] 1062 - Duplicate entry '1' for key 'PRIMARY'

我們看結(jié)果可以知道INSERT INTO test_tab VALUES (1, '3');這一句因為主鍵沖突運行失敗,從而這一條下面的commit也沒有執(zhí)行。

需要注意的是:這時已經(jīng)開啟了一個事務(wù),并且已經(jīng)執(zhí)行了一條正確的插入語句,雖然沒有體現(xiàn)在數(shù)據(jù)庫中,但如果以后在該連接中又執(zhí)行了一條commit 或begin或start transaction(新開一個事務(wù)會將該鏈接中的其他未提交的事務(wù)提交,相當(dāng)于commit?。┠銜l(fā)現(xiàn)已經(jīng)將剛才的INSERT INTO test_tab VALUES (1, '2');寫進了數(shù)據(jù)庫。

MySQL中怎么實現(xiàn)事物回滾

MySQL中怎么實現(xiàn)事物回滾

上述就是小編為大家分享的MySQL中怎么實現(xiàn)事物回滾了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章名稱:MySQL中怎么實現(xiàn)事物回滾
文章出自:http://bm7419.com/article18/jdcddp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站網(wǎng)站導(dǎo)航、搜索引擎優(yōu)化建站公司、云服務(wù)器移動網(wǎng)站建設(shè)

廣告

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

手機網(wǎng)站建設(shè)