gpt4 book ai didi

MySQL 触发器与 UPDATE 上的 IF 语句

转载 作者:行者123 更新时间:2023-11-29 21:37:47 24 4
gpt4 key购买 nike

我想创建一个触发器。

这是我的两张 table ,

  1. kk_settlements

    | paidBy | paidTo | settlementAmount | createdAt | groupId |
  2. 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

我哪里出错了?我想我在触发器中使用 paidBypaidTo 时出错了。请纠正我。

还建议是否有更好的方法来完成同样的事情。我愿意接受建议。

最佳答案

尝试 NEW.paidBy 和 NEW.paidTo。

这就是引用 FOR EACH ROW 当前行的值的方式。在 UPDATE 触发器中,您可以使用 OLD 和 NEW 来引用字段的前一个值以及要更改为的值。

关于MySQL 触发器与 UPDATE 上的 IF 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34779694/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com