首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用insert into和insert

如何使用insert into和insert
EN

Stack Overflow用户
提问于 2021-12-02 05:39:19
回答 1查看 979关注 0票数 0

我想做的是我有两个桌子-- t1t2t1是主表,来自t2的信息每天都被插入到t1中。

我试图使用insert和join在一起,这样t1t2中的所有匹配数据都不会再次插入到t1中。

我只想将表t2中的唯一项插入到t1中。

表T1:

代码语言:javascript
复制
Date                Details
-------------------------------
01-02-2021 11.02    completed
01-02-2021 01.30    cancelled

表T2:

代码语言:javascript
复制
Date                Details
-------------------------------
01-02-2021 11.02    completed
01-02-2021 01.30    cancelled
02-03-2021 03.30    running
02-03-2021 05.30    failed
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-02 07:02:27

我建议你用EXCEPT

示例:

代码语言:javascript
复制
INSERT INTO T1( [Date], Details )
SELECT [Date], Details
FROM T2
EXCEPT -- This is equivalent to subtracting T1 records from T2 records
SELECT [Date], Details
FROM T1

您也可以使用LEFT JOIN来完成它。

代码语言:javascript
复制
INSERT INTO T1( [Date], Details )
SELECT [Date], Details
FROM T2
    -- Add all of the columns that you want to match one.
    LEFT JOIN T1 ON T2.[Date] = T1.[Date] AND T2.Details = T1.Details
-- This ensures that only records that did not match T1 are returned.
WHERE T1.[Date] IS NULL

如果要在要匹配表的列的顶部返回其他列(在SELECT列列表中),则左联接方法非常有用。

如果要对表的所有输出列进行筛选,则方法更适合。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70194665

复制
相关文章

相似问题

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