首頁 >資料庫 >mysql教程 >如何使用觸發器和視圖來追蹤和查看 MySQL 中的資料庫變更?

如何使用觸發器和視圖來追蹤和查看 MySQL 中的資料庫變更?

Patricia Arquette
Patricia Arquette原創
2024-12-07 04:16:11964瀏覽

How Can I Track and View Database Changes in MySQL Using Triggers and Views?

使用 MySQL 追蹤資料庫變更歷史

許多資料庫系統需要能夠追蹤一段時間內對記錄所做的變更。 MySQL 提供了一種簡單的技術來實現這一點。考慮一個名為“data”的資料表,您要監視它的變更。

首先,為「data」建立一個具有相同結構的歷史表,除了三個附加欄位:

  • 操作: VARCHAR(8) 預設值'插入'
  • 修訂版: INT(6) NOT NULL auto_increment
  • dt_datetime: DATETIME NOT NULL 預設 CURRENT_TIMESTAMP

這些列儲存操作(插入/更新/

接下來,建立觸發器來擷取這些操作並填入歷史表:

  • 插入觸發器後: INSERT INTO data_history (action, revision, dt_datetime , ...) SELECT 'insert', NULL, NOW(), ... FROM data WHERE ...
  • 更新觸發器後: INSERT INTO data_history (action, revision, dt_datetime, ...) SELECT 'update', NULL, NOW(), ... FROM data WHERE ...
  • 刪除先前觸發器: INSERT INTO data_history (action, revision, dt_datetime, ...) SELECT 'delete', NULL, NOW(), ... FROM data WHERE ...

現在,所有資料變更都會記錄在「 data_history”表中。要顯示更新中特定列的更改,您可以在主鍵和序列列上將歷史表與其自身連接:

CREATE VIEW data_history_changes AS
SELECT t2.dt_datetime, t2.action, t1.row_id,
IF(t1.a_column = t2.a_column, t1.a_column, t1.a_column || " to " || t2.a_column) AS a_column
FROM data_history AS t1 INNER JOIN data_history AS t2
ON t1.row_id = t2.row_id
WHERE (t1.revision = 1 AND t2.revision = 1) OR t2.revision = t1.revision + 1
ORDER BY t1.row_id ASC, t2.revision ASC

這應該提供對歷史表所做的所有更改的緊湊歷史視圖“數據”表。

以上是如何使用觸發器和視圖來追蹤和查看 MySQL 中的資料庫變更?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn