Aracılığıyla paylaş


sys.ledger_table_history (Transact-SQL)

Şunlar için geçerlidir: SQL Server 2022 (16.x) ve sonraki sürümleri Azure SQL VeritabanıAzure SQL Yönetilen Örneği

Defter tablolarındaki kriptografik korumalı işlem geçmişini yakalar: defter tabloları oluşturmak, defter tablolarını veya defter görünümlerini yeniden adlandırmak ve defter tablolarını kaldırmak.

Veritabanı defteri hakkında daha fazla bilgi için bkz. Defter

Sütun adı Veri türü Description
object_id int Defter tablosunun nesne kimliği.
schema_name sysname Defter tablosunu içeren şemanın adı. İşlem şema adını değiştirdiyse, bu sütun yeni şema adını yakalar.
table_name sysname Defter tablosunun adı. İşlem tablo adını değiştirdiyse, bu sütun yeni tablo adını yakalar.
ledger_view_schema_name sysname Defter tablosunun defter görünümünü içeren şemanın adı. İşlem şema adını değiştirdiyse, bu sütun yeni şema adını yakalar.
ledger_view_name sysname Defter tablosunun defter görünümünün adı. İşlem görünüm adını değiştirdiyse, bu sütun yeni görünüm adını yakalar.
operation_type tinyint İşlemin türünü gösteren sayısal değer

0 = CREATE – bir defter tablosu oluşturmak.
1 = DROP – defter tablosunu düşürmek.
2 = READ - defter tablosunun yeniden adlandırılması.
3 = RENAME_VIEW - defter görünümünün defter tablosu için yeniden adlandırılması.
operation_type_desc nvarchar(60) operation_type değerinin metinsel açıklaması.
transaction_id bigint Defter tablosunda işlemi içeren kimlik işlemi. sys.database_ledger_transactions'de bir satırı tanımlar.
sequence_number bigint İşlem içindeki işlemin dizisi numarası.

Permissions

DEFTER İÇERİĞİNİ GÖRÜNTÜLEME izni gerektirir.

Örnekler

Defter tablolarındaki aşağıdaki işlem dizisini ele alalım.

  1. Bir kullanıcı defter tablosu oluşturur.

    CREATE TABLE [Employees]
    (
        EmployeeID INT NOT NULL,
        Salary Money NOT NULL
    )
    WITH (SYSTEM_VERSIONING = ON, LEDGER = ON);
    GO
    
  2. Bir kullanıcı defter tablosunun adını değiştirir.

    EXEC sp_rename 'Employees', 'Employees_Copy';
    
  3. Bir kullanıcı, defter tablosunun defter görünümünü yeniden adlandırır.

    EXEC sp_rename 'Employees_Ledger', 'Employees_Ledger_Copy';
    
  4. Bir kullanıcı defter tablosunu düşürür.

    DROP TABLE [Employees];
    

Aşağıdaki sorgu, sys.ledger_table_history ve sys.database_ledger_transactions birleştirerek defter tablolarındaki değişikliklerin geçmişini, her değişikliğin ve değişikliğin zamanını ve tetikleyen kullanıcının adını üretmektedir.

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

Ayrıca bakınız