我想创建一个触发器。
这是我的两张 table ,
kk_settlements
表| paidBy | paidTo | settlementAmount | createdAt | groupId |
kk_user_relations
表| userId | userId_1 | groupId | amount |
现在,当 kk_settlements
上存在 INSERT
时,我想创建触发器和 UPDATE
kk_user_relations
表。
在执行UPDATE
之前,我想检查paidBy
是否小于或大于paidTo
,并根据该结果查找行要更新的 kk_user_relations
表。 (由于 kk_user_relations
中的所有行均由 userId
<userId_1
我尝试添加以下触发器
(我正在使用phpmyadmin)
IF (paidBy < paidTo)
THEN
UPDATE kk_user_relations
SET kk_user_relations.amount = kk_user_relations.amount + settlementAmount
WHERE kk_user_relations.userId = paidBy
AND kk_user_relations.userId_1 = paidTo
AND kk_user_relations.groupId = groupId;
ELSE
UPDATE kk_user_relations
SET kk_user_relations.amount = kk_user_relations.amount + settlementAmount
WHERE kk_user_relations.userId_1 = paidBy
AND kk_user_relations.userId = paidTo
AND kk_user_relations.groupId = groupId;
END IF
此触发器
不起作用并引发错误。
#1054 - Unknown column 'paidBy' in 'field list'
由 phpmyadmin 生成的完整触发器
是
DROP TRIGGER IF EXISTS `kk_update_user_relations`;
CREATE DEFINER=`root`@`localhost` TRIGGER `kk_update_user_relations`
AFTER INSERT ON `kk_settlements`
FOR EACH ROW
IF (paidBy < paidTo) THEN
UPDATE kk_user_relations
SET kk_user_relations.amount = kk_user_relations.amount + settlementAmount
WHERE kk_user_relations.userId = paidBy
AND kk_user_relations.userId_1 = paidTo
AND kk_user_relations.groupId = groupId;
ELSE UPDATE kk_user_relations
SET kk_user_relations.amount = kk_user_relations.amount + settlementAmount
WHERE kk_user_relations.userId_1 = paidBy
AND kk_user_relations.userId = paidTo
AND kk_user_relations.groupId = groupId;
END IF
我哪里出错了?我想我在触发器中使用 paidBy
和 paidTo
时出错了。请纠正我。
还建议是否有更好的方法来完成同样的事情。我愿意接受建议。
最佳答案
尝试 NEW.paidBy 和 NEW.paidTo。
这就是引用 FOR EACH ROW 当前行的值的方式。在 UPDATE 触发器中,您可以使用 OLD 和 NEW 来引用字段的前一个值以及要更改为的值。
关于MySQL 触发器与 UPDATE 上的 IF 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34779694/