SQL Server 2008 聯(lián)機(jī)叢書(2009 年 5 月)
使用 TRUNCATE TABLE 刪除所有行
若要?jiǎng)h除表中的所有行,則 TRUNCATE TABLE 語句是一種快速、有效的方法。TRUNCATE TABLE 與不含 WHERE 子句的 DELETE 語句類似。但是,TRUNCATE TABLE 速度更快,并且使用更少的系統(tǒng)資源和事務(wù)日志資源。
與 DELETE 語句相比,TRUNCATE TABLE 具有以下優(yōu)點(diǎn):
- 所用的事務(wù)日志空間較少。
DELETE 語句每次刪除一行,并在事務(wù)日志中為所刪除的每行記錄一個(gè)項(xiàng)。TRUNCATE TABLE 通過釋放用于存儲(chǔ)表數(shù)據(jù)的數(shù)據(jù)頁來刪除數(shù)據(jù),并且在事務(wù)日志中只記錄頁釋放。
- 使用的鎖通常較少。
當(dāng)使用行鎖執(zhí)行 DELETE 語句時(shí),將鎖定表中各行以便刪除。TRUNCATE TABLE 始終鎖定表和頁,而不是鎖定各行。
- 如無例外,在表中不會(huì)留有任何頁。
執(zhí)行 DELETE 語句后,表仍會(huì)包含空頁。例如,必須至少使用一個(gè)排他 (LCK_M_X) 表鎖,才能釋放堆中的空表。如果執(zhí)行刪除操作時(shí)沒有使用表鎖,表(堆)中將包含許多空頁。對于索引,刪除操作會(huì)留下一些空頁,盡管這些頁會(huì)通過后臺(tái)清除進(jìn)程迅速釋放。
與 DELETE 語句相同,使用 TRUNCATE TABLE 清空的表的定義與其索引和其他關(guān)聯(lián)對象一起保留在數(shù)據(jù)庫中。如果表中包含標(biāo)識(shí)列,該列的計(jì)數(shù)器將重置為該列定義的種子值。如果未定義種子,則使用默認(rèn)值 1。若要保留標(biāo)識(shí)計(jì)數(shù)器,請使用 DELETE。

Microsoft SQL Server 引入一種功能,此功能可刪除或截?cái)喑^ 128 個(gè)區(qū)的表,而無需同時(shí)保留需要?jiǎng)h除的所有區(qū)的鎖。有關(guān)詳細(xì)信息,請參閱刪除并重新生成大型對象。

下面的示例刪除 JobCandidate
表中的所有數(shù)據(jù)。在 TRUNCATE TABLE
語句之前和之后使用 SELECT
語句來比較結(jié)果。
USE AdventureWorks; GO SELECT COUNT(*) AS BeforeTruncateCount FROM HumanResources.JobCandidate; GO TRUNCATE TABLE HumanResources.JobCandidate; GO SELECT COUNT(*) AS AfterTruncateCount FROM HumanResources.JobCandidate; GO