程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> 更多數據庫知識 >> TRUNCATE 快速刪除表中的所有數據

TRUNCATE 快速刪除表中的所有數據

編輯:更多數據庫知識

備注

與 DELETE 語句相比,TRUNCATE TABLE 具有以下優點:

所用的事務日志空間較少。

DELETE 語句每次刪除一行,並在事務日志中為所刪除的每行記錄一個條目。TRUNCATE TABLE 通過釋放用於存儲表數據的數據頁來刪除數據,並且在事務日志中只記錄頁釋放。


使用的鎖通常較少。

當使用行鎖執行 DELETE 語句時,將鎖定表中各行以便刪除。TRUNCATE TABLE 始終鎖定表和頁,而不是鎖定各行。


表中將毫無例外地不留下任何頁。

執行 DELETE 語句後,表仍會包含空頁。例如,必須至少使用一個排他 (LCK_M_X) 表鎖,才能釋放堆中的空表。如果執行刪除操作時沒有使用表鎖,表(堆)中將包含許多空頁。對於索引,刪除操作會留下一些空頁,盡管這些頁會通過後台清除進程迅速釋放。


TRUNCATE TABLE 刪除表中的所有行,但表結構及其列、約束、索引等保持不變。若要刪除表定義及其數據,請使用 DROP TABLE 語句。

如果表包含標識列,該列的計數器重置為該列定義的種子值。如果未定義種子,則使用默認值 1。若要保留標識計數器,請使用 DELETE。

限制

不能對以下表使用 TRUNCATE TABLE:
由 FOREIGN KEY 約束引用的表。
參與索引視圖的表。

通過使用事務復制或合並復制發布的表。

對於具有以上一個或多個特征的表,請使用 DELETE 語句。

TRUNCATE TABLE 不能激活觸發器,因為該操作不記錄各個行刪除。有關詳細信息,請參閱 CREATE TRIGGER (Transact-SQL)。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved