SQL Server (Transact-SQL) INSERT INTO SELECT 关键字用于使用另一个表填充一个表。请注意,另一个表应该具有填充第一个表所需的字段集。
语法
在 SQL Server 中使用 INSERT INTO SELECT 关键字的语法 (Transact -SQL) 如下:
INSERT INTO table1 [(column1, column2, ...)]
SELECT column1, column2, ... FROM table2
[WHERE condition];
示例:
考虑一个数据库,其中包含名为 Employee 和 HREmployee 的表,其内容如下记录:
表 1:Employee 表
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
1 | John | London | 25 | 3000 |
2 | Marry | New York | 24 | 2750 |
3 | Jo | Paris | 27 | 2800 |
4 | Kim | Amsterdam | 30 | 3100 |
5 | Ramesh | New Delhi | 28 | 3000 |
6 | Huang | Beijing | 28 | 2800 |
表 2:HREmployee 表
HREmployee 表不包含任何记录,并具有以下字段 - HRID、姓名 和 地址。
HREmployee表的给定字段可以使用Employee填充使用以下查询查询表:
INSERT INTO HREmployee (HRID, Name, Address)
SELECT EmpID, Name, City FROM Employee
WHERE EmpID IN (1, 4, 5);
-- 查看结果
SELECT * from HREmployee
现在HREmployee表将包含以下记录:
HRID | Name | Address |
---|---|---|
1 | John | London |
4 | Kim | Amsterdam |
5 | Ramesh | New Delhi |