Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
Ş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.
Bir kullanıcı defter tablosu oluşturur.
CREATE TABLE [Employees] ( EmployeeID INT NOT NULL, Salary Money NOT NULL ) WITH (SYSTEM_VERSIONING = ON, LEDGER = ON); GOBir kullanıcı defter tablosunun adını değiştirir.
EXEC sp_rename 'Employees', 'Employees_Copy';Bir kullanıcı, defter tablosunun defter görünümünü yeniden adlandırır.
EXEC sp_rename 'Employees_Ledger', 'Employees_Ledger_Copy';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