溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Truncate/Delete/Drop table的特點(diǎn)和區(qū)別

發(fā)布時(shí)間:2020-07-05 08:15:33 來(lái)源:網(wǎng)絡(luò) 閱讀:2426 作者:Darren_Chen 欄目:MySQL數(shù)據(jù)庫(kù)

之前一直對(duì)Truncate/Delete/Drop認(rèn)識(shí)的不是很清晰,所以特意的翻了一下MySQL5.7 Reference Manual,準(zhǔn)備系統(tǒng)的了解一下,這里是一些翻譯,外加一點(diǎn)自己的認(rèn)知。


Truncate的特點(diǎn)

  • 邏輯上truncate table和delete from table_name;相似,但是過(guò)程是先drop table,然后在re-create table,如果要清空一個(gè)大表的所有數(shù)據(jù)行,truncate比delete高效;

  • Truncate是一個(gè)DDL操作,一旦執(zhí)行會(huì)隱式提交,這就說(shuō)明truncate無(wú)法rollback,所以執(zhí)行之前需謹(jǐn)慎;

  • 如果表被鎖住,truncate會(huì)報(bào)錯(cuò);

  • 如果有外鍵約束,truncate也會(huì)報(bào)錯(cuò);

  • 對(duì)于InnoDB/MyISAM表的auto_increment的列,truncate table之后可以重新使用序列值;

  • truncate table無(wú)法觸發(fā)delete相關(guān)的觸發(fā)器;


Delete的特點(diǎn)

Delete是DML操作,如果沒有提交,可以rollback;

對(duì)于InnoDB/MyISAM表的auto_increment的列,delete table之后可以無(wú)法重新使用序列值,但是重啟之后可以重新使用序列;

Delete from table_name后面一定要跟where條件,否則會(huì)刪除表的所有行;


Drop的特點(diǎn)

Drop table除了在數(shù)據(jù)庫(kù)層面刪除表,還會(huì)在系統(tǒng)層面刪除xxx.ibd,xxx.frm(InnoDB表)或 xxx.MYD,xxx.MYI,xxx.frm (MyISAM)等文件;

drop table if exists table_name可以防止表不存在的報(bào)錯(cuò),但是會(huì)有一個(gè)warning;

drop table也會(huì)隱式提交,除了臨時(shí)表;


參考鏈接

https://dev.mysql.com/doc/refman/5.7/en/truncate-table.html

https://dev.mysql.com/doc/refman/5.7/en/delete.html

https://dev.mysql.com/doc/refman/5.7/en/drop-table.html

向AI問一下細(xì)節(jié)

免責(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)容。

AI