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

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

成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供龍華網(wǎng)站建設(shè)、龍華做網(wǎng)站、龍華網(wǎng)站設(shè)計(jì)、龍華網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、龍華企業(yè)網(wǎng)站模板建站服務(wù),10余年龍華做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

Truncate的特點(diǎn)

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

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

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

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

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

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

Delete的特點(diǎn)

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

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

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

Drop的特點(diǎn)

Drop table除了在數(shù)據(jù)庫層面刪除表,還會(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

網(wǎng)站名稱:Truncate/Delete/Droptable的特點(diǎn)和區(qū)別
文章位置:http://muchs.cn/article26/gjsocg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)網(wǎng)站改版、網(wǎng)站制作、電子商務(wù)、網(wǎng)頁設(shè)計(jì)公司、企業(yè)網(wǎng)站制作

廣告

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

成都網(wǎng)頁設(shè)計(jì)公司