tableA(no,name1,status,time)和tableB(no,name1)
no为主键
A表要同步B表的数据,status记录改信息是“新增”或者“修改”或者“删除”
time为新增或修改或删除的时间
这个SQL要怎么写 ?求具体的语句啊谢谢!
tableA(no,name1,status,time)和tableB(no,name1)
no为主键
A表要同步B表的数据,status记录改信息是“新增”或者“修改”或者“删除”
time为新增或修改或删除的时间
这个SQL要怎么写 ?求具体的语句啊谢谢!
这是我写的一个sql文件,你保存成sql文件可以试试。
DELIMITER $$
INSERT INTO tablea (SELECT tableb.no,tableb.`name`,'Add',tableb.time from tableb WHERE no NOT IN (SELECT no from tablea));
UPDATE tablea INNER JOIN tableb SET status = 'Update', tablea.name=tableb.name, tablea.time = tableb.time WHERE tablea.no = tableb.no AND tablea.name != tableb.name;
UPDATE tablea INNER JOIN tableb SET status = 'DEL', tablea.time = NOW() WHERE tablea.no NOT IN (SELECT no FROM tableb);
$$
DELIMITER ;