首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有一些相似行的数据迁移2表

具有一些相似行的数据迁移2表
EN

Stack Overflow用户
提问于 2020-01-30 18:24:10
回答 3查看 57关注 0票数 0

我有两张已经存档的表格。对于数据很少的单个日期,它们具有相同的行。我需要将表2记录插入到表1中。当我这样做的时候,我会得到唯一约束忽略的错误。如何实现它。是否有任何提示要忽略已存在的数据,只插入新记录。

EN

回答 3

Stack Overflow用户

发布于 2020-01-30 18:49:25

你可以使用这个:

代码语言:javascript
复制
INSERT INTO destTable
SELECT Field1,Field2,Field3,... 
FROM srcTable
WHERE NOT EXISTS(SELECT * 
                 FROM destTable 
                 WHERE (srcTable.Field1=destTable.Field1 and
                       SrcTable.Field2=DestTable.Field2...etc.)
                 )
票数 2
EN

Stack Overflow用户

发布于 2020-01-30 19:08:52

您可以使用SET运算符MINUS来实现如下结果:

代码语言:javascript
复制
INSERT INTO TABLE1 (<COLUMN NAMES>)
SELECT <COLUMN NAMES> FROM TABLE2
MINUS
SELECT <COLUMN NAMES> FROM TABLE1

根据oracle documentation is对MINUS操作符的描述

对第一个查询选择的所有不同行执行

操作,而不是第二个查询

干杯!!

票数 0
EN

Stack Overflow用户

发布于 2020-01-30 20:07:38

另一种可能的解决方案是使用MERGE,在下面的link上,你可以找到一个有用的教程,详细解释它。

代码语言:javascript
复制
MERGE INTO table1 a
    USING table2 b ON (a.col1 = b.col1) -- define your own search condition
        WHEN NOT MATCHED THEN
            INSERT (a.col1, a.col2, a.col3 ...)
            VALUES (b.col1, b.col2, b.col3 ...);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59983808

复制
相关文章

相似问题

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