0

我使用 SqlServer 2008 Tracking Changes 的跟踪更改同步了两个数据库,这很酷,因为我可以毫不费力地控制数据库的插入/更新和删除并发送到另一个数据库。目前我正在将系统迁移到 MySQL。是否存在类似于跟踪更改的东西,或者我必须手动实现它。

手动实现这一点是一个好方法,使用时间戳来控制 INSERTS/UPDATES 和触发器来填充删除表来控制 DELETES?

当我说时间戳时,我想说的是 SQLServer 时间戳(插入、修改寄存器时自动递增的二进制字段。是否存在类似于 MySQL 中的 SQLServer 时间戳的东西?

谢谢

4

1 回答 1

0

是的,您可以使用 MySQL TIMESTAMP 字段监视表中的更改(插入、更新);必须使用ON UPDATE CURRENT_TIMESTAMP选项创建 TIMESTAMP 字段。它将帮助您了解记录何时更改。

例如 -

CREATE TABLE table1(
  id INT(11) NOT NULL,
  name VARCHAR(255) DEFAULT NULL,
  ts TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (id)
);

此处的更多信息 - TIMESTAMP 的自动初始化和更新

于 2012-07-27T06:25:48.907 回答