我有一个名为 的表teamMembers
,该表存储一个人的姓名和电子邮件地址:
id INT (UNIQUE, AUTOINCREMENT)
name VARCHAR(255)
email VARCHAR(255)
updated DATETIME
created TIMESTAMP
我已经创建了我的触发器phpMyAdmin
,它在这个导出中看起来像这样:
CREATE TRIGGER teamMembers.updated_updater
AFTER UPDATE ON teamMembers
FOR EACH ROW
BEGIN
UPDATE teamMembers SET updated = NOW() WHERE id = OLD.id;
END
所以当我使用这样的查询时:
UPDATE teamMembers SET name = 'test' WHERE id = 1
我应该将更新的列设置为当前日期时间。
但这不起作用,我收到以下错误消息:
#1442 - 无法更新存储函数/触发器中的表 'teamMembers',因为它已被调用此存储函数/触发器的语句使用。
我真的不知道这里有什么问题。我认为这是因为这个触发器也会调用它自己,因此会变成一个无限循环。我认为必须有一种方法可以自动更新刚刚更新的记录而不改变我的查询。
有人可以帮我使用 MySQL 触发器更新到updated
列吗?