使用 MySQL 追蹤資料庫變更歷史
許多資料庫系統需要能夠追蹤一段時間內對記錄所做的變更。 MySQL 提供了一種簡單的技術來實現這一點。考慮一個名為“data”的資料表,您要監視它的變更。
首先,為「data」建立一個具有相同結構的歷史表,除了三個附加欄位:
這些列儲存操作(插入/更新/
接下來,建立觸發器來擷取這些操作並填入歷史表:
現在,所有資料變更都會記錄在「 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中文網其他相關文章!