您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)MySQL數(shù)據(jù)庫(kù)中需要commit嗎,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
mysql在進(jìn)行如插入(insert)操作的時(shí)候需不需要commit,這得看你的存儲(chǔ)引擎,如果是不支持事務(wù)的引擎,如myisam,則是否commit都沒(méi)有效的。
推薦課程:MySQL教程。
如果是支持事務(wù)的引擎,如innodb,則得知道你事物支持是否自動(dòng)提交事務(wù)(即commit)
看自己的數(shù)據(jù)庫(kù)是否是自動(dòng)commit,可以使用mysql> show variables like '%autocommit%';來(lái)進(jìn)行查看,如果是OFF即不自動(dòng)commit,需要手動(dòng)commit操作(命令行可以直接“commit;“命令),否則是自動(dòng)commit。
提交數(shù)據(jù)有三種類型:顯式提交、隱式提交及自動(dòng)提交。
下面分 別說(shuō)明這三種類型。
顯式提交
用 COMMIT 命令直接完成的提交為顯式提交。
隱式提交
用 SQL 命令間接完成的提交為隱式提交。這些命令是:
ALTER , AUDIT , COMMENT , CONNECT , CREATE , DISCONNECT , DROP , EXIT , GRANT , NOAUDIT , QUIT, REVOKE , RENAME 。
自動(dòng)提交
若把 AUTOCOMMIT 設(shè)置為 ON ,則在插入、修改、刪除語(yǔ)句執(zhí)行后,
系統(tǒng)將自動(dòng)進(jìn)行提交,這就是自動(dòng)提交。其格式為: SQL>SET AUTOCOMMIT ON ;
COMMIT / ROLLBACK這兩個(gè)命令用的時(shí)候要小心。 COMMIT / ROLLBACK 都是用在執(zhí)行 DML語(yǔ)句(INSERT / DELETE / UPDATE / SELECT )之后的。DML 語(yǔ)句,執(zhí)行完之后,處理的數(shù)據(jù),都會(huì)放在回滾段中(除了 SELECT 語(yǔ)句),等待用戶進(jìn)行提交(COMMIT)或者回滾 (ROLLBACK),當(dāng)用戶執(zhí)行 COMMIT / ROLLBACK后,放在回滾段中的數(shù)據(jù)就會(huì)被刪除。(SELECT 語(yǔ)句執(zhí)行后,數(shù)據(jù)都存在共享池。提供給其他人查詢相同的數(shù)據(jù)時(shí),直接在共享池中提取,不用再去數(shù)據(jù)庫(kù)中提取,提高了數(shù)據(jù)查詢的速度。)
所有的 DML 語(yǔ)句都是要顯式提交的,也就是說(shuō)要在執(zhí)行完DML語(yǔ)句之后,執(zhí)行 COMMIT 。而其他的諸如 DDL 語(yǔ)句的,都是隱式提交的。也就是說(shuō),在運(yùn)行那些非 DML 語(yǔ)句后,數(shù)據(jù)庫(kù)已經(jīng)進(jìn)行了隱式提交,例如 CREATE TABLE,在運(yùn)行腳本后,表已經(jīng)建好了,并不在需要你再進(jìn)行顯式提交。
關(guān)于MySQL數(shù)據(jù)庫(kù)中需要commit嗎就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。