触发器是在插入,更新或删除数据时更新同一张表或另一张表的好方法。但是,它们很难正确实现,因为您必须小心确保触发器能够实现预期的效果,并且不会产生意外的副作用。因此,值得花费一些时间来熟悉CREATE TRIGGER命令的语法。这是完整的语法供参考:
您需要为trigger_event选择INSERT。关于trigger_time,它可以在INSERT操作之前或之后。BEFORE是比较UPDATE或DELETE操作上的旧值的理想选择。对于INSERT,您可能应该坚持使用AFTER。
现在,我想向您展示一些来自Sakila示例数据库的触发器示例。这是一个以虚构的视频租赁商店为主题的学习型MySQL数据库。它包含几个触发器,您可以使用它们来查看它们的作用。
有几对与您所寻找的相似;第一个是ins_film触发器。这是我在Navicat for MySQL中的定义 数据库开发和管理客户端:
在Navicat中,触发器在表设计器中自己的选项卡中进行管理。您可以看到,这是一个INSERT触发器,在更新行之后将触发该触发器。ins_film触发器通过INSERT将新行复制到另一个表。相反,执行更新将很容易。为此,您将需要一个唯一的标识符。在这种情况下,film_id会做得很好。
要查看运行中的UPDATE,我们可以看一下upd_film触发器。它在film_text表中复制对film表的所有UPDATE操作。
如果仔细查看UPDATE语句,您将看到用于查找确切记录的WHERE子句。现在,我对您的表一无所知,但希望您拥有某种ID字段,可用于标识要更新的行。如果您的数据库被规范化为3rd Normal Form,则看不到任何阻止您这样做的东西。