首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用mysql将丢失的记录从一个表插入到另一个表

使用mysql将丢失的记录从一个表插入到另一个表
EN

Stack Overflow用户
提问于 2012-10-25 00:02:25
回答 5查看 20.6K关注 0票数 7

我不知道为什么我会对这个查询感到困惑。

我有两个表:包含900记录的Table A和包含800记录的Table B。这两个表需要包含相同的数据,但存在一些不匹配。

我需要编写一个mysql查询来将缺少的100记录从Table A插入到Table B

最后,Table ATable B应该是相同的。

我不想先截断所有条目,然后再从另一个表执行插入操作。所以请多多帮助,我们将不胜感激。

谢谢。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2015-07-11 02:14:58

使用LEFT OUTER JOIN也可以做到这一点。这将避免子查询开销(当系统可能为外部查询的每个记录执行子查询一次时),就像John Woo的答案中那样,并将避免像user2340435中的那样覆盖现有的800条记录的不必要的工作:

代码语言:javascript
运行
复制
INSERT INTO b
SELECT a.* FROM a
LEFT OUTER JOIN b ON b.id = a.id
WHERE b.id IS NULL;

这将首先选择AB表中的所有行,包括这两个表中的所有列,但是对于存在于A中而不存在于B中的行,B表的所有列都将为NULL。然后,它只过滤后面的行(WHERE b.id IS NULL),最后将所有这些行插入到B表中。

票数 20
EN

Stack Overflow用户

发布于 2012-10-25 00:20:08

我认为你可以使用IN来做这件事。(这是您的查询的简化)

代码语言:javascript
运行
复制
INSERT INTO table2 (id, name)
SELECT id, name
FROM table1
WHERE (id,name) NOT IN 
       (SELECT id, name
        FROM table2);

SQLFiddle Demo

正如您在演示中看到的,table2只有1条记录,但在执行查询后,在table2上插入了2条记录。

票数 5
EN

Stack Overflow用户

发布于 2014-09-11 05:20:05

如果是mysql,并且表是相同的,那么这应该是可行的:

代码语言:javascript
运行
复制
REPLACE INTO table1 SELECT * FROM table2;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13053052

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档