将行从一个表插入到另一个表,在 SQL Server 上具有相同的架构和复合键

2022-11-09数据库问题
3

本文介绍了将行从一个表插入到另一个表,在 SQL Server 上具有相同的架构和复合键的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有两个具有相同模式和复合键的表,表 a 和表 b

I have two tables with identical schemas and composite keys, table a and table b

我需要从表 a 向表 b 中插入行,其中表 b 中不存在相同的键.

I need to insert rows into table b from table a, where an identical key does not already exists in table b.

我该怎么做?

推荐答案

-- Set up sample data
CREATE TABLE A(Key1 int NOT NULL, Key2 nvarchar(10) NOT NULL, Data nvarchar(20))
INSERT INTO A(Key1, Key2, Data) Values(10, 'AA', 'My first value')
SELECT * INTO B FROM A
INSERT INTO A(Key1, Key2, Data) Values(20, 'BA', 'My second value')

-- Copy the missing rows from table A to table B
INSERT INTO B(Key1, Key2, Data)
SELECT A.Key1, A.Key2, A.Data
FROM A
LEFT JOIN B ON A.Key1 = B.Key1 AND A.Key2 = B.Key2
WHERE B.Key1 IS NULL

这篇关于将行从一个表插入到另一个表,在 SQL Server 上具有相同的架构和复合键的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End
SQLServer SQL Server

相关推荐

如何在 sql server 2012 中部署现有的 SSIS 包?
How to deploy a existing SSIS Package in sql server 2012?(如何在 sql server 2012 中部署现有的 SSIS 包?)...
2024-04-16 数据库问题
11

“无法连接到本地 MySQL 服务器"在 docker-compose 中
quot;Can#39;t connect to local MySQL serverquot; in docker-compose(“无法连接到本地 MySQL 服务器在 docker-compose 中)...
2024-04-16 数据库问题
51

在 SQL Server 中设计 1:1 和 1:m 关系
Designing 1:1 and 1:m relationships in SQL Server(在 SQL Server 中设计 1:1 和 1:m 关系)...
2024-04-16 数据库问题
2

主键的 Sql 数据类型 - SQL Server?
Sql Data Type for Primary Key - SQL Server?(主键的 Sql 数据类型 - SQL Server?)...
2024-04-16 数据库问题
4

SQL Server:如何限制表包含单行?
SQL Server: how to constrain a table to contain a single row?(SQL Server:如何限制表包含单行?)...
2024-04-16 数据库问题
3

SQL Server 中数据库范围的唯一但简单的标识符
Database-wide unique-yet-simple identifiers in SQL Server(SQL Server 中数据库范围的唯一但简单的标识符)...
2024-04-16 数据库问题
4