12

当我尝试在我的数据库中创建两个 TIMESTAMP 列时遇到了一个问题。一呼created一呼updatedCURRENT_TIMESTAMP我认为将两者的默认值设置为然后ON UPDATE CURRENT_TIMESTAMPupdated列设置会很容易。但由于某种原因,MySQL 意味着这是一个坏主意……所以我一直在寻找方法来做到这一点,而不必在插入查询中设置其中一个。

我通过在这个答案中使用触发器找到了一种方法,但我不断收到错误。我刚刚设法实际创建了触发器,但是现在当我尝试插入声称该触发器的新行时出现错误

1442 - 无法更新存储函数/触发器中的表“任务”,因为它已被调用此存储函数/触发器的语句使用。

我完全不明白这意味着什么。所以,我希望这里有人可以阐明这个主题。

我用来创建表和触发器的SQL如下:

CREATE TABLE `tasks` (
  `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
  `created` DATETIME,
  `updated` TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `title` VARCHAR(255) NOT NULL,
  `notes` TEXT,
  `status_id` INT(10) UNSIGNED NOT NULL,
  PRIMARY KEY (`id`),
  KEY `status_id` (`status_id`),
  CONSTRAINT `fk_tasks_statuses` FOREIGN KEY (`status_id`) REFERENCES `statuses` (`id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


CREATE TRIGGER task_creation_timestamp AFTER INSERT ON tasks 
FOR EACH ROW
UPDATE tasks SET created = updated WHERE id = NEW.id;

我在这里做错了什么?

4

1 回答 1

28

您的触发器需要在“插入之前”,并且您需要使用SET而不是UPDATE

CREATE TRIGGER task_creation_timestamp BEFORE INSERT ON tasks 
FOR EACH ROW
SET NEW.created = NOW();
于 2010-05-25T17:54:08.540 回答