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操作。希望这对你有所帮助!

    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站