您好,登錄后才能下訂單哦!
之前一直對(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
免責(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)容。