使用 TRUNCATE TABLE 刪除所有行

          Posted on 2009-07-16 19:41 林光炎 閱讀(1470) 評論(0)  編輯  收藏 所屬分類: ORACLE
          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。

           截?cái)啻笮捅?

          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
          

          posts - 104, comments - 33, trackbacks - 0, articles - 0

          Copyright © 林光炎

          主站蜘蛛池模板: 上蔡县| 集安市| 新密市| 延吉市| 大连市| 赤水市| 逊克县| 芦山县| 凉城县| 阜宁县| 海丰县| 威宁| 高平市| 邵阳市| 临沭县| 平舆县| 衡阳县| 靖西县| 赫章县| 鲁甸县| 贞丰县| 公安县| 罗源县| 巨鹿县| 阜康市| 渝中区| 石狮市| 呼图壁县| 东城区| 陇川县| 青岛市| 祁连县| 湘潭市| 定州市| 衡东县| 楚雄市| 石家庄市| 沁阳市| 屏山县| 洛隆县| 西城区|