適用於:SQL Server
如果是完整復原模式之下的資料庫,則大量匯入執行的所有資料列插入作業,都會完整記錄在交易記錄中。 若使用完整復原模式,大型的資料匯入作業可能會使交易記錄檔很快就填滿。 相較之下,在簡單復原模式或大量記錄復原模式之下,大量匯入作業的最少記錄會減少大量匯入作業填滿記錄空間的機會。 最低限度記錄也比完整記錄更有效率。
注意
大量記錄復原模式的設計目的,是要在大量匯入作業期間暫時取代完整復原模式。
最低限度記錄大量匯入作業的資料表需求
使用最低限度記錄時,目標資料表必須符合下列條件:
資料表未被複寫。
指定表格鎖定 (使用
TABLOCK)。注意
雖然在最低記錄的大量匯入作業期間,資料插入不會記錄在交易記錄中,但每次將新的延伸範圍配置給資料表時,資料庫引擎仍會記錄延伸範圍配置。
資料表不是經記憶體最佳化的資料表。
資料表是否能產生最低限度記錄,還需視資料表是否已建立索引而定,若已建立索引,則需考量資料表是否為空白:
若資料表沒有索引,則資料頁會使用最低限度記錄。
若資料表沒有叢集索引,但有一或多個非叢集索引,則資料頁會一律使用最低限度記錄。 但索引頁的記錄方式,則取決於資料表是否空白:
若資料表空白,則索引頁會使用最低限度記錄。 若一開始您以空白資料表與多個批次來進行大量匯入資料,則在第一個批次中,索引頁與資料頁都會使用最低限度記錄,但從第二個批次開始,就只有資料頁會使用最低限度記錄。
如果資料表不是空白,則索引頁會使用完整記錄。
如果其中一個索引具有
IGNORE_DUP_KEY = ON,則會完整記載索引及資料頁面。
若資料表有叢集索引但為空白,則資料頁與索引頁都會使用最低限度記錄。 相對地,若資料表有 B 型樹狀結構叢集索引且並非空白,則不論復原模式為何,資料頁與索引頁都會使用完整記錄。 如果您從空白的資料列存放區資料表開始,並批次大量匯入資料,則索引和資料頁面都會針對第一個批次最少記錄,但從第二個批次開始,只會大量記錄資料頁面。
注意
文件通常會使用「B 型樹狀結構」一詞來指稱索引。 在資料列存放區索引中,資料庫引擎會實作 B+ 樹狀結構。 這不適用於資料行存放區索引或經記憶體最佳化的資料表。 如需詳細資訊,請參閱 SQL Server 和 Azure SQL 索引架構和設計指南。
如需叢集資料行存放區索引 (CCI) 的資訊,請參閱資料行存放區索引資料載入指導。
注意
啟用交易式複寫時, BULK INSERT 即使在大量記錄復原模型下,作業也會完整記錄。
相關工作
- 復原模式 (SQL Server)
- bcp 公用程式
- BULK INSERT (Transact-SQL)
- OPENROWSET (Transact-SQL)
- BACKUP (Transact-SQL)
- ALTER DATABASE (Transact-SQL)
- 表格提示 (Transact-SQL)
- 插入 (Transact-SQL)