SQL Server: Tập lệnh theo dõi bảng mới được Insert, Update trong SQL Server
1. Sử dụng System Dynamic Management Views (DMV)
Query cơ bản theo dõi thay đổi trong 24 giờ qua:
SELECT
OBJECT_NAME(object_id) AS TableName,
last_user_update AS LastUpdate,
user_updates AS TotalUpdates,
last_user_seek AS LastSeek,
last_user_scan AS LastScan
FROM
sys.dm_db_index_usage_stats
WHERE
database_id = DB_ID()
AND last_user_update > DATEADD(HOUR, -24, GETDATE())
ORDER BY
last_user_update DESC;Query chi tiết với thông tin schema:
SELECT
t.name AS TableName,
s.name AS SchemaName,
ius.last_user_update AS LastUpdateTime,
ius.user_updates AS TotalUpdates,
ius.last_user_seek AS LastSeekTime,
ius.last_user_scan AS LastScanTime
FROM
sys.dm_db_index_usage_stats ius
JOIN
sys.tables t ON ius.object_id = t.object_id
JOIN
sys.schemas s ON t.schema_id = s.schema_id
WHERE
ius.database_id = DB_ID()
AND ius.last_user_update > DATEADD(HOUR, -24, GETDATE())
ORDER BY
ius.last_user_update DESC;Check for recently modified tables:
2. Sử dụng Change Tracking (Theo dõi thay đổi)
Bật Change Tracking cho database:
Bật Change Tracking cho bảng cụ thể:
Truy vấn thông tin thay đổi:
3. Sử dụng Change Data Capture (CDC) - Phiên bản Enterprise
Bật CDC cho database:
Bật CDC cho bảng cụ thể:
Truy vấn thay đổi:
4. Phương pháp thủ công với Timestamp Columns
Thêm cột timestamp vào bảng:
Tạo trigger để tự động cập nhật:
Truy vấn các bảng được cập nhật gần đây:
5. Tạo bảng Log để theo dõi thay đổi
Tạo bảng log:
Tạo trigger để ghi log:
Kết luận
PreviousSQL Server: Tập lệnh để tìm tất cả các giá trị Mặc định với CộtNextSQL Server: Cách khởi động SQLServer bỏ qua Database bị lỗi
Last updated