主頁 > 知識庫 > MySQL刪除表操作實現(delete、truncate、drop的區(qū)別)

MySQL刪除表操作實現(delete、truncate、drop的區(qū)別)

熱門標簽:常州網絡外呼系統開發(fā) 外呼系統電銷受騙 走過哪個省地圖標注 萊西市地圖標注 巫師三血與酒地圖標注 銷售語音電話機器人 在哪里申請400電話 安徽ai電話電銷機器人有效果嗎 400電話申請信用卡

本文主要講mysql中三種刪除表的操作,delete語句、truncate語句以及drop語句的區(qū)別:

簡介

delete

1、刪除整張表的數據:

delete from table_name;

2、刪除部分數據,添加where子句:

delete from table_name where...;

3、說明

  1)、屬于DML語言,每次刪除一行,都在事務日志中為所刪除的每行記錄一項。產生rollback,事務提交之后才生效;如果有相應的 trigger,執(zhí)行的時候將被觸發(fā),如果刪除大數據量的表速度會很慢。
 ?。玻h除表中數據而不刪除表的結構(定義),同時也不釋放空間。

truncate

1、只能操作表,將表中數據全部刪除,在功能上和不帶where子句的delete語句相同:

truncate table table_name;

2、說明

  1)、默認情況下,truncate通過釋放存儲表數據所用的數據頁來刪除數據,并且只在事務日志中記錄頁的釋放。所以使用的系統和事務日志資源少,可以使用reuse storage; truncate會將高水線復位(回到最開始).
  2 )、 truncate是DDL語言, 操作立即生效,自動提交,原數據不放到rollback segment中,不能回滾. 操作不觸發(fā)trigger.
  3 )、刪除內容、釋放空間但不刪除表的結構(定義)。

drop

1、drop語句將刪除表的結構,以及被依賴的約束(constrain),觸發(fā)器(trigger),索引(index);

drop table table_name;

2、說明
  1)、刪除之后,依賴于該表的存儲過程/函數將保留,但是變?yōu)閕nvalid狀態(tài).
  2)、drop也屬于DDL語言,立即執(zhí)行,執(zhí)行速度最快
  3)、刪除內容和定義,釋放空間。

區(qū)別

1、表和索引所占空間:
  當表被TRUNCATE 后,這個表和索引所占用的空間會恢復到初始大?。?
  DELETE操作不會減少表或索引所占用的空間;
  DROP語句將表所占用的空間全釋放掉。

2、應用范圍:
  TRUNCATE 只能對table;
  DELETE可以是table和view。

3、執(zhí)行速度: drop > truncate > delete

4、delete from刪空表后,會保留一個空的頁,truncate在表中不會留有任何頁。

5、DELETE語句執(zhí)行刪除的過程是每次從表中刪除一行,并且同時將該行的刪除操作作為事務記錄在日志中保存以便進行進行回滾操作。

TRUNCATE TABLE 則一次性地從表中刪除所有的數據并不把單獨的刪除操作記錄記入日志保存,刪除行是不能恢復的。并且在刪除的過程中不會激活與表有關的刪除觸發(fā)器。執(zhí)行速度快。

6、當使用行鎖執(zhí)行 DELETE 語句時,將鎖定表中各行以便刪除。truncate始終鎖定表和頁,而不是鎖定各行。

7、如果有identity產生的自增id列,delete from后仍然從上次的數開始增加,即種子不變;

使用truncate刪除之后,種子會恢復到初始值。

總結

1、delete 語句可以使用where子句實現部分刪除,而truncate不可以,會將表中的整個數據全部刪除,使用時,可以按需求選擇;
2、如果想從表中刪除所有的數據,不要使用delete,可以使用truncate語句,因為這樣執(zhí)行速度更快。truncate語句實際是刪除原來的表然后重新建立一個新表;
3、在沒有備份情況下,謹慎使用 drop 與 truncate。要刪除表結構使用drop;
4、對于由 FOREIGN KEY 約束引用的表,不能使用 TRUNCATE TABLE,而應使用不帶 WHERE 子句的 DELETE 語句。由于 TRUNCATE TABLE 不記錄在日志中,所以它不能激活觸發(fā)器。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL Truncate用法詳解
  • MySQL中truncate誤操作后的數據恢復案例
  • mysql 刪除操作(delete+TRUNCATE)
  • MySQL刪除數據Delete與Truncate語句使用比較
  • 詳解MySQL中DROP,TRUNCATE 和DELETE的區(qū)別實現mysql從零開始
  • MySQL用truncate命令快速清空一個數據庫中的所有表

標簽:河北 陽江 果洛 赤峰 來賓 煙臺 鞍山 黃石

巨人網絡通訊聲明:本文標題《MySQL刪除表操作實現(delete、truncate、drop的區(qū)別)》,本文關鍵詞  MySQL,刪除,表,操作,實現,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL刪除表操作實現(delete、truncate、drop的區(qū)別)》相關的同類信息!
  • 本頁收集關于MySQL刪除表操作實現(delete、truncate、drop的區(qū)別)的相關信息資訊供網民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章