我有两个表设置了触发器,这样在一个表上的插入将触发第二个表的同一主键的列的增量(因为两个表都通过外键链接),但是目前仅增量一次,然后对于任何后续插入都不会增量。我的想法是,这可能与我设置 key 的方式有关,但我不确定,有人可以解释一下吗:
CREATE TABLE Members(
ID INT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE,
FIRST_NAME TEXT(16),
LAST_NAME TEXT(16),
TITLE TEXT(7), /** 7 CHARS for 'Student'*/
INSTITUTION VARCHAR(2048),
No_Publications INT NOT NULL,
PRIMARY KEY(ID)
);
CREATE TABLE Papers(
ISBN INT UNSIGNED NOT NULL UNIQUE,
Title TEXT(4),
Publish_Date DATE NOT NULL,
Topic TEXT(128),
PRIMARY KEY(ISBN)
);
CREATE TABLE Publications(
Author_ID INT UNSIGNED NOT NULL UNIQUE,
ISBN INT UNSIGNED NOT NULL UNIQUE,
PRIMARY KEY (Author_ID, ISBN),
FOREIGN KEY(Author_ID) REFERENCES Members(ID) ON DELETE RESTRICT ON UPDATE CASCADE,
FOREIGN KEY(ISBN) REFERENCES Papers(ISBN) ON DELETE RESTRICT ON UPDATE CASCADE /**Used in
many to many relations*/
);
CREATE TRIGGER New_Publication AFTER INSERT ON Publications
FOR EACH ROW
UPDATE Members SET No_Publications = No_Publications + 1
WHERE Members.ID = Publications.Author_ID;
编辑:我希望 No_Publications 随着出版物表上的插入而增加
编辑2:实现NEW
关键字后,自动增量现在可以工作,但是现在会发生以下情况:
向 1 个新成员添加 1 篇新论文后,该论文将在数据库中注册,但是,尽管成员表中发生增量,但随后向同一成员添加的论文不会注册。
插入到出版物表中是由于上面为了透明度而附加的论文表的结果。
最佳答案
触发器应该是:
CREATE TRIGGER New_Publication AFTER INSERT ON Publications
FOR EACH ROW
UPDATE Members SET No_Publications = No_Publications + 1
WHERE Members.ID = NEW.Author_ID;
尽管他的专栏也应该在删除时更新,并且此专栏会再次出现database normalization因为您可以在没有列的情况下获取此信息,因此它仅在某些情况下对提高性能和避免计数有用。
关于mySql 触发器未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48051137/