所以我有两张这样的桌子......
ext_words
-------------
| id | word |
-------------
| 1 | this |
-------------
| 2 | that |
-------------
| 3 | this |
-------------
ext_words_count
---------------------
| id | word | count |
---------------------
| 1 | this | 2 |
---------------------
| 2 | that | 1 |
---------------------
我正在尝试创建一个触发器,它将:
- 更新
ext_words_count.count
时ext_words.word
更新。
让事情更复杂的是,
- 如果更新时
ext_words.word
不存在,我想将其插入并设置为1。ext_words_count
ext_words
ext_words_count
count
我一直在研究类似的问题:
1. 使用自动增量字段插入触发器之前/之后,以及
2. 使用触发器更新另一个数据库中
的表试图结合 2.这是我到目前为止的内容:
DELIMITER $$
CREATE TRIGGER update_count
AFTER UPDATE ON ext_words
FOR EACH ROW
BEGIN
UPDATE ext_words_count
SET word_count = word_count + 1
WHERE word = NEW.word;
END;
$$
DELIMITER ;
非常感谢任何建议和指导。或者可能是我忽略的另一种方法,并且一如既往地提前感谢!
更新:
我选择使用 2 个触发器,一个用于 INSERT,一个用于 UPDATE,因为我对 MySQL 中的条件语句不太熟悉。
DELIMITER $$
CREATE TRIGGER insert_word AFTER INSERT ON ext_words
FOR EACH ROW
BEGIN
INSERT IGNORE INTO ext_words_count (word) VALUES (NEW.word);
END;
$$
DELIMITER ;
和
DELIMITER $$
CREATE TRIGGER update_word AFTER UPDATE ON ext_words
FOR EACH ROW
BEGIN
UPDATE ext_words_count
SET word_count = word_count + 1
WHERE word = NEW.word;
END;
$$
DELIMITER ;
INSERT 查询运行良好,但是 UPDATE 查询没有更新word_count
。我在更新查询中错过了什么..?