之前有个需求,一直没搞定,有没有大佬来帮忙看下。
同一个数据库两张表,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操作。希望这对你有所帮助!
解决 无用评论 打赏 举报
悬赏问题
- ¥35 平滑拟合曲线该如何生成
- ¥100 c语言,请帮蒟蒻写一个题的范例作参考
- ¥15 名为“Product”的列已属于此 DataTable
- ¥15 安卓adb backup备份应用数据失败
- ¥15 eclipse运行项目时遇到的问题
- ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
- ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
- ¥15 自己瞎改改,结果现在又运行不了了
- ¥15 链式存储应该如何解决
- ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站