背景:不知道原来有一个A表是专门存储备注信息的,新建了B表,导致同一个存储功能的表分在了两个数据库,表名和字段名不一样。为了后续方便,现在想把B表的数据合并在A表中。因为有一些数据是在A表中已经存在了的,所以A表存在了的就要更新,不存在的就要插入。
思路:把生产上两个不同的表结构和数据导出 .sql 文件,放在本地同一个数据库中,使用联表SQL把需要更新和插入的数据统计出来,并用SQL的字符串拼接语法拼接好SQL,后续只需要在生产执行拼接好的SQL即可。
以下是代码展示
-- 插入的SQL
SELECT CONCAT('INSERT INTO app_manager_rcmder_remark (rcmder_id, manager_id,remark_name,active_status,`create_time`,`last_update_time`) VALUES (''', recomender_no, ''', ''', user_id, ''', ''', remark_name, ''', ''', 1, ''',now(),now());')
from bms_app_remarks_name
-- 更新的SQL
SELECT CONCAT('UPDATE `app_manager_rcmder_remark` SET `remark_name` = ''', remark_name, ''' WHERE `manager_id` = ''', user_id, ''' AND `rcmder_id` = ''', recomender_no, ''';')
FROM bms_app_remarks_name