這期內(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ā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運(yùn)維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
事物的概念:
事物由一個單獨(dú)單元的一個或多個sql語句組成,如果其中一個語句不能完成,整個單元就會回滾,所有影響到的數(shù)據(jù)將返回到事物開始以前的狀態(tài)。因而,只有事物中的所有語句都成功執(zhí)行才能說明這個事物被成功的執(zhí)行。
這句話的本身沒有什么問題,但是請看下面的案例
mysql事務(wù)中有兩條insert語句,其中第二條語句是錯誤的,在運(yùn)行完事務(wù)后,第一條仍然插進(jìn)去了,代碼如下。
//創(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');這一句因為主鍵沖突運(yùn)行失敗,從而這一條下面的commit也沒有執(zhí)行。
需要注意的是:這時已經(jīng)開啟了一個事務(wù),并且已經(jīng)執(zhí)行了一條正確的插入語句,雖然沒有體現(xiàn)在數(shù)據(jù)庫中,但如果以后在該連接中又執(zhí)行了一條commit 或begin或start transaction(新開一個事務(wù)會將該鏈接中的其他未提交的事務(wù)提交,相當(dāng)于commit!)你會發(fā)現(xiàn)已經(jīng)將剛才的INSERT INTO test_tab VALUES (1, '2');寫進(jìn)了數(shù)據(jù)庫。
上述就是小編為大家分享的MySQL中怎么實現(xiàn)事物回滾了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
文章名稱:MySQL中怎么實現(xiàn)事物回滾
文章出自:http://m.2m8n56k.cn/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)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)