sys.ledger_table_history (Transact-SQL)
適用於: SQL Server 2022 (16.x) Azure SQL DatabaseAzure 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 許可權。
範例
請考慮總帳資料表上的下列作業順序。
使用者建立總帳資料表。
CREATE TABLE [Employees] ( EmployeeID INT NOT NULL, Salary Money NOT NULL ) WITH (SYSTEM_VERSIONING = ON, LEDGER = ON); GO
使用者重新命名總帳資料表。
EXEC sp_rename 'Employees', 'Employees_Copy';
使用者重新命名總帳資料表的總帳檢視。
EXEC sp_rename 'Employees_Ledger', 'Employees_Ledger_Copy';
使用者卸載總帳資料表。
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
另請參閱
意見反應
https://aka.ms/ContentUserFeedback。
即將登場:在 2024 年,我們將逐步淘汰 GitHub 問題作為內容的意見反應機制,並將它取代為新的意見反應系統。 如需詳細資訊,請參閱:提交並檢視相關的意見反應