之前有个需求,一直没搞定,有没有大佬来帮忙看下。
同一个数据库两张表,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操作。希望这对你有所帮助!
解决 无用评论 打赏 举报
悬赏问题
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器