weixin_43860213 2019-12-23 22:54 采纳率: 0%
浏览 394

MYsql触发器判断语句。。有没有大佬来看看。老是报错

之前有个需求,一直没搞定,有没有大佬来帮忙看下。
同一个数据库两张表,A,B。字段不同。当A表插入数据,判断uid在B表中的UID是否存在,如果一样,则同步A表中的字段,a1,a2,a3到B表中的b1,b2,b3.
如果不存在,在B表中插入A表中的数据,a1,a2和b1,b2一一对应,但是字段名不同。一直测试没结果。

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 03:57
    关注

    针对你的问题,可能是因为 MYSQL 触发器判断语句语法错误导致的报错。在你的触发器逻辑中,可以使用 IF NOT EXISTS 语句来检查 B 表中是否存在 uid 值。同时,可以使用 NEW 关键字来表示当前正在插入到 A 表中的行。

    以下是一个可能有效的 MYSQL 触发器代码示例:

    DELIMITER //
    CREATE TRIGGER sync_b_table AFTER INSERT ON A
    FOR EACH ROW
    BEGIN
    IF NOT EXISTS (SELECT uid FROM B WHERE uid = NEW.uid) THEN
    INSERT INTO B (b1, b2, b3)
    VALUES (NEW.a1, NEW.a2, NEW.a3);
    ELSE
    UPDATE B
    SET b1 = NEW.a1, b2 = NEW.a2, b3 = NEW.a3
    WHERE uid = NEW.uid;
    END IF;
    END;
    //

    此触发器将在插入 A 表时进行同步操作,如果 uid 值在 B 表中不存在,则插入新行,否则更新 B 表中的对应行。

    请在你的 MYSQL 数据库中测试这段代码,并在遇到问题时进行必要的debug操作。希望这对你有所帮助!

    评论

报告相同问题?

悬赏问题

  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大