我想创建一个触发器来创建一个新的表Row。我是"触发语言"的新手,我需要你的帮助。
我的数据库如下所示。
user
----------------------------------------------------
| userid | username | password | full_name | email |
----------------------------------------------------
| 67 | testuser | xxxxxxxx | thefullna | email |
----------------------------------------------------
| 68 | testuse2 | xxxxxxxx | thefulln2 | email |
----------------------------------------------------
| 69 | testuse3 | xxxxxxxx | thefulln3 | email |
----------------------------------------------------
highscore_easy
------------------------------------------------------
| ID | user | time | date | level | userid |
------------------------------------------------------
| 200 | testuser | 11113233 | date | 444 | 0 |
------------------------------------------------------
| 201 | testuse2 | 11113235 | date | 444 | 0 |
------------------------------------------------------
| 203 | testuse3 | 11113236 | date | 444 | 0 |
------------------------------------------------------
如果创建了一个新用户,则会在"用户"表中创建一个新行。当新行被创建时,我想创建一个触发器,在"highscore_easy"中创建一个"DEFAULT"行。
默认行必须采用"用户"表中填写的用户名,默认行中的时间、日期和级别可以为"0","highscore_easy"中的USERID必须与"用户"中的用户ID相同。
所以如果我现在创建一个用户:
user
----------------------------------------------------
| userid | username | password | full_name | email |
----------------------------------------------------
| 88 | example | xxxxxxxx | thefullna | email |
----------------------------------------------------
highscore_easy
------------------------------------------------------
| ID | user | time | date | level | userid |
------------------------------------------------------
| 200 | example | 0 | 0 | 0 | 88 |
------------------------------------------------------
ID将在highscore_easy中自行创建。
如果我犯了一些错误,很抱歉我的英语不好。如果你能帮我,那就太棒了。
也许有一种方法可以在没有触发器的情况下解决这个问题,但我不知道其他解决方案。
您可以尝试以下操作:
DELIMITER $$
CREATE TRIGGER `ai_user` AFTER INSERT ON user
FOR EACH ROW BEGIN
INSERT INTO highscore_easy
SET
user = NEW.username,
userid = NEW.userid,
time = 0,
date = 0,
level = 0;
END
在单个触发器中,您可以根据需要插入任意数量的内容:
DELIMITER $$
CREATE TRIGGER `ai_user` AFTER INSERT ON user
FOR EACH ROW BEGIN
INSERT INTO highscore_easy
SET
user = NEW.username,
userid = NEW.userid,
time = 0,
date = 0,
level = 0;
INSERT INTO highscore_expert
SET
user = NEW.username,
userid = NEW.userid,
time = 0,
date = 0,
level = 0;
END