drop、truncate和delete的區別

(1)DELETE語句執行刪除的過程是每次從表中刪除一行,而且同時將該行的刪除操做做爲事務記錄在日誌中保存以便進行進行回滾操做。函數

   TRUNCATE TABLE 則一次性地從表中刪除全部的數據並不把單獨的刪除操做記錄記入日誌保存,刪除行是不能恢復的。而且在刪除的過程當中不會激活與表有關的刪除觸發器。執行速度快。日誌

(2)表和索引所佔空間。索引

   當表被TRUNCATE 後,這個表和索引所佔用的空間會恢復到初始大小,事務

   DELETE操做不會減小表或索引所佔用的空間。資源

   drop語句將表所佔用的空間全釋放掉。it

(3)通常而言,drop > truncate > deletetable

(4)應用範圍。效率

    TRUNCATE 只能對TABLE;         DELETE能夠是table和view引用

(5)TRUNCATE 和DELETE只刪除數據, DROP則刪除整個表(結構和數據)。總結

(6)truncate與不帶where的delete :只刪除數據,而不刪除表的結構(定義)drop語句將刪除表的結構被依賴的約束(constrain),觸發器(trigger)索引(index);依賴於該表的存儲過程/函數將被保留,但其狀態會變爲:invalid。

(7)delete語句爲DML(data maintain Language),這個操做會被放到 rollback segment中,事務提交後才生效。若是有相應的 tigger,執行的時候將被觸發。

(8)truncate、drop是DLL(data define language),操做當即生效,原數據不放到 rollback segment中,不能回滾

(9)在沒有備份狀況下,謹慎使用 drop 與 truncate。要刪除部分數據行採用delete且注意結合where來約束影響範圍。回滾段要足夠大。要刪除表用drop;若想保留表而將表中數據刪除,若是於事務無關,用truncate便可實現。若是和事務有關,或老師想觸發trigger,仍是用delete。

(10) Truncate table 表名 速度快,並且效率高,由於: 
truncate table 在功能上與不帶 WHERE 子句的 DELETE 語句相同:兩者均刪除表中的所有行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系統和事務日誌資源少。DELETE 語句每次刪除一行,並在事務日誌中爲所刪除的每行記錄一項。TRUNCATE TABLE 經過釋放存儲表數據所用的數據頁來刪除數據,而且只在事務日誌中記錄頁的釋放。 

(11) TRUNCATE TABLE 刪除表中的全部行,但表結構及其列、約束、索引等保持不變。新行標識所用的計數值重置爲該列的種子。若是想保留標識計數值,請改用 DELETE。若是要刪除表定義及其數據,請使用 DROP TABLE 語句。 

(12) 對於由 FOREIGN KEY 約束引用的表,不能使用 TRUNCATE TABLE,而應使用不帶 WHERE 子句的 DELETE 語句。因爲 TRUNCATE TABLE 不記錄在日誌中,因此它不能激活觸發器。

1、delete

一、delete是DML,執行delete操做時,每次從表中刪除一行,而且同時將該行的的刪除操做記錄在redo和undo表空間中以便進行回滾(rollback)和重作操做,但要注意表空間要足夠大,須要手動提交(commit)操做才能生效,能夠經過rollback撤消操做。

二、delete可根據條件刪除表中知足條件的數據,若是不指定where子句,那麼刪除表中全部記錄。

三、delete語句不影響表所佔用的extent,高水線(high watermark)保持原位置不變。

2、truncate

一、truncate是DDL,會隱式提交,因此,不能回滾,不會觸發觸發器。

二、truncate會刪除表中全部記錄,而且將從新設置高水線和全部的索引,缺省狀況下將空間釋放到minextents個extent,除非使用reuse storage,。不會記錄日誌,因此執行速度很快,但不能經過rollback撤消操做(若是一不當心把一個表truncate掉,也是能夠恢復的,只是不能經過rollback來恢復)。

三、對於外鍵(foreignkey )約束引用的表,不能使用 truncate table,而應使用不帶 where 子句的 delete 語句。

四、truncatetable不能用於參與了索引視圖的表。

3、drop

一、drop是DDL,會隱式提交,因此,不能回滾,不會觸發觸發器。

二、drop語句刪除表結構及全部數據,並將表所佔用的空間所有釋放。

三、drop語句將刪除表的結構所依賴的約束,觸發器,索引,依賴於該表的存儲過程/函數將保留,可是變爲invalid狀態。

 

總結:

一、在速度上,通常來講,drop> truncate > delete。

二、在使用drop和truncate時必定要注意,雖然能夠恢復,但爲了減小麻煩,仍是要慎重。

三、若是想刪除部分數據用delete,注意帶上where子句,回滾段要足夠大;

   若是想刪除表,固然用drop; 

   若是想保留表而將全部數據刪除,若是和事務無關,用truncate便可;

   若是和事務有關,或者想觸發trigger,仍是用delete;

   若是是整理表內部的碎片,能夠用truncate跟上reuse stroage,再從新導入/插入數據。

相關文章
相關標籤/搜索