MySQL - 触发触发器时重复 PK,但直接插入记录时不重复 PK

标签 mysql sql database triggers

我有以下 MySQL 触发器。它因 tbl_users 的更新而被触发。如果当天已经存在记录,它将用一些信息更新 tbl_user_stats;如果当天没有记录,它将在 tbl_user_stats 中插入一条新记录。 action_date 是 tbl_user_stats 的 PK,它保存日期。

drop trigger if exists trigger_update_user_stats_upgrades_and_downgrades$$


CREATE TRIGGER trigger_update_user_stats_upgrades_and_downgrades AFTER UPDATE ON tbl_users
 FOR EACH ROW BEGIN
DECLARE date_now int;
IF NEW.premium <> OLD.premium THEN

    SET date_now = (SELECT count(*) from tbl_user_stats WHERE DATE(action_date) = CURDATE());
    IF date_now > 0 THEN
        IF NEW.premium = 0 THEN
            UPDATE tbl_user_stats SET downgrades = downgrades + 1 WHERE DATE(action_date) = CURDATE();
        ELSE
            UPDATE tbl_user_stats SET upgrades = upgrades + 1 WHERE DATE(action_date) = CURDATE();  
        END IF;
    ELSE
        IF NEW.premium = 0 THEN
            INSERT INTO tbl_user_stats (action_date, downgrades) values (CURDATE() + INTERVAL 1 DAY, 1);
        ELSE
            INSERT INTO tbl_user_stats (action_date, upgrades) values (CURDATE() + INTERVAL 1 DAY, 1);
        END IF;
    END IF;
END IF;
END$$

在底部,我插入 CURDATE() + INTERVAL 1 DAY 以进行测试。我正在尝试模拟第二天执行的 tbl_users 更新。因此,如果今天是 2013 年 11 月 22 日,我想假装 tbl_users 中的记录于 2013 年 11 月 23 日更新。如果触发器正常工作,tbl_user_stats 应该插入一条新记录,其 action_date 为 11/23/13。

问题是,当我尝试更新 tbl_users 时,收到一条错误消息,提示“主键重复 11/23/13”。但是,tbl_user_stats 中没有设置为 11/23/13 的主键。当我使用 11/23/13 作为 PK 手动将新记录插入 tbl_user_stats 时,没有问题。仅当我尝试更新 tbl_users 时才会出现问题。为什么我会收到重复主键错误?

最佳答案

我已经重现了这个错误。 发生这种情况是因为您正在检查“date_now”的条件正在检查 CURDATE() 当您使用 CURDATE() + INTERVAL 1 DAY 插入时 要模拟第二天,您应该将所有日期比较更改为 CURDATE() + INTERVAL 1 DAY

sqlFiddle code with all CURDATE() changed to CURDATE + INTERVAL 1 DAY摆脱错误。 要重现错误,只需更改

SET date_now = (SELECT count(*) from t2 WHERE DATE(start_date) = CURDATE()+ INTERVAL 1 DAY);

SET date_now = (SELECT count(*) from t2 WHERE DATE(start_date) = CURDATE());`

关于MySQL - 触发触发器时重复 PK,但直接插入记录时不重复 PK,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20152087/

相关文章:

php - 如何修复我的代码以使用 php、mysql 在数组中保存 3 个值来进行调查?

mysql - 将 90% 的行的字段设置为 NULL 是否有效?

sql - 使用 PK 将行插入 SQL Server 表中特定位置

mysql - 运行Docker容器时自动启动mysql

java - Android 使用 jdbc 连接到 google cloud sql

sql - 使用空列创建唯一约束

java - Hibernate CriteriaQuery 如何查找具有两个条件的整数列表

python - mysql为一个人存储多个别名

mysql - mysql数据库结构问题

mysql - 防止所有非唯一列的重复行(仅限 MySQL)?