之前有个需求,一直没搞定,有没有大佬来帮忙看下。
同一个数据库两张表,A,B。字段不同。当A表插入数据,判断uid在B表中的UID是否存在,如果一样,则同步A表中的字段,a1,a2,a3到B表中的b1,b2,b3.
如果不存在,在B表中插入A表中的数据,a1,a2和b1,b2一一对应,但是字段名不同。一直测试没结果。
MYsql触发器判断语句。。有没有大佬来看看。老是报错
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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操作。希望这对你有所帮助!
解决 无用评论 打赏 举报