MySQL 触发器与 UPDATE 上的 IF 语句

标签 mysql phpmyadmin

我想创建一个触发器。

这是我的两张 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/

相关文章:

mysql - 存储过程中的 case 语句问题

php - 使用 MySQL 从另一个表复制数据时缺少行

PHP MySql PDO 多重插入不起作用

java - JDBC MySQL 提示连接过多

php - MYSQL/PHP 查找与给定项目关联的最常见项目

php - php 中出现 MySQL 错误,但 phpmyadmin 中没有错误

mysql - 使用 phpmyadmin 导入表需要很长时间

phpMyAdmin 复制表

Mysql Innodb优化表

mysql - 如何对 MySQL 中的另一个表进行 ORDER BY CALCULATED SUM