共用方式為


sys.ledger_table_history (Transact-SQL)

適用於:SQL Server 2022 (16.x) Azure SQL 資料庫 Azure SQL 受控執行個體

擷取總賬數據表上作業的密碼編譯保護歷程記錄:建立總賬數據表、重新命名總賬數據表或總賬檢視,以及卸除總賬數據表。

如需資料庫總賬的詳細資訊,請參閱 總賬

資料行名稱 資料類型 描述
object_id int 總賬數據表的物件標識碼。
schema_name sysname 包含總賬數據表的架構名稱。 如果作業已變更架構名稱,此數據行會擷取新的架構名稱。
table_name sysname 總賬數據表的名稱。 如果作業已變更資料表名稱,此數據行會擷取新的資料表名稱。
ledger_view_schema_name sysname 包含總賬數據表總賬檢視的架構名稱。 如果作業已變更架構名稱,此數據行會擷取新的架構名稱。
ledger_view_name sysname 總賬數據表的總賬檢視名稱。 如果作業已變更檢視名稱,則此數據行會擷取新的檢視名稱。
operation_type tinyint 數值,表示作業的類型

0 = CREATE – 建立總賬數據表。
1 = DROP – 卸除總賬數據表。
2 = RENAME - 重新命名總賬數據表。
3 = RENAME_VIEW - 重新命名總賬數據表的總賬檢視。
operation_type_desc nvarchar(60) operation_type 值的文字描述。
transaction_id bigint 在總賬數據表中包含作業的標識符交易。 它會識別sys.database_ledger_transactions中的數據列。
sequence_number bigint 交易中作業的序號。

權限

需要 VIEW LEDGER CONTENT 許可權。

範例

請考慮總賬數據表上的下列作業順序。

  1. 使用者建立總賬數據表。

    CREATE TABLE [Employees]
    (
        EmployeeID INT NOT NULL,
        Salary Money NOT NULL
    )
    WITH (SYSTEM_VERSIONING = ON, LEDGER = ON);
    GO
    
  2. 使用者重新命名總賬數據表。

    EXEC sp_rename 'Employees', 'Employees_Copy';
    
  3. 使用者重新命名總賬數據表的總賬檢視。

    EXEC sp_rename 'Employees_Ledger', 'Employees_Ledger_Copy';
    
  4. 使用者卸除總賬數據表。

    DROP TABLE [Employees];
    

下列查詢會聯結sys.ledger_table_history和sys.database_ledger_transactions,以產生總賬數據表變更的歷程記錄,包括每次變更的時間,以及觸發變更的用戶名稱。

SELECT 
t.[principal_name]
, t.[commit_time]
, h.[schema_name] + '.' + h.[table_name] AS [table_name]
, h.[ledger_view_schema_name] + '.' + h.[ledger_view_name] AS [view_name]
, h.[operation_type_desc]
FROM sys.ledger_table_history h
JOIN sys.database_ledger_transactions t
ON h.transaction_id = t.transaction_id

另請參閱