sys.ledger_column_history (Transact-SQL)
適用於:SQL Server 2022 (16.x) Azure SQL 資料庫 Azure SQL 受控執行個體
擷取總賬數據表數據行上作業的密碼編譯保護歷程記錄:新增、重新命名和卸除數據行。
如需資料庫總賬的詳細資訊,請參閱 總賬
資料行名稱 | 資料類型 | 描述 |
---|---|---|
object_id | int | 總賬數據表的物件標識碼。 |
column_id | int | 總賬數據表中數據行的數據行標識碼。 |
column_name | sysname | 總賬數據表中數據行的名稱。 如果作業已變更資料行名稱,此數據行會擷取新的資料行名稱。 |
operation_type | tinyint | 數值,表示作業的類型 0 = CREATE – 使用 CREATE TABLE 建立包含資料行之數據表的一部分來建立數據行。 1 = ADD – 使用 ALTER TABLE/ADD COLUMN 在總賬數據表中新增數據行。 2 = RENAME - 重新命名總賬數據表中的數據行。 3 = DROP - 卸除總賬數據表中的數據行。 |
operation_type_desc | nvarchar(60) | operation_type 值的文字描述。 |
transaction_id | bigint | 資料庫唯一的交易識別碼(它對應至資料庫事務歷史記錄中的交易標識符)。 |
sequence_number | bigint | 交易中作業的序號。 |
權限
需要 VIEW LEDGER CONTENT 許可權。
範例
請考慮總賬數據表上的下列作業順序。
使用者建立總賬數據表。
CREATE TABLE [Employees] ( EmployeeID INT NOT NULL, Salary Money NOT NULL ) WITH (SYSTEM_VERSIONING = ON, LEDGER = ON); GO
用戶會將數據行新增至總賬數據表。
ALTER TABLE [Employees] ADD Lastname NVARCHAR(256) NULL;
使用者重新命名總賬數據表的數據行。
EXEC sp_rename 'dbo.Employees.Lastname', 'Firstname', 'COLUMN';
使用者卸除總賬數據表的數據行。
ALTER TABLE [Employees] DROP COLUMN Firstname;
下列查詢會聯結sys.ledger_column_history和sys.database_ledger_transactions,以產生總賬數據表數據行變更的歷程記錄,包括每次變更的時間,以及觸發變更的用戶名稱。
SELECT
t.[principal_name]
, t.[commit_time]
, h.[column_name] AS [column_name]
, h.[operation_type_desc]
FROM sys.ledger_column_history h
JOIN sys.database_ledger_transactions t
ON h.transaction_id = t.transaction_id
ORDER BY t.[commit_time];