SELECT INTO 和 INSERT INTO SELECT 两种表复制语句「终于解决」

编程好6博客 (50) 2023-07-01 19:12

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说SELECT INTO 和 INSERT INTO SELECT 两种表复制语句「终于解决」,希望能够帮助你!!!。

0.参考文献

SELECT INTO 和 INSERT INTO SELECT 两种表复制语句

1.INSERT INTO SELECT语句

      语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1

      要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:

 --1.创建表
 create table OrderDetail2
 (
    SalesOrderDetailID int primary key not null,
    SalesOrderID int,
    CarrierTrackingNumber nvarchar(25)
 );

 --2.插入数据
 Insert into OrderDetail2(SalesOrderDetailID,SalesOrderID,CarrierTrackingNumber) 
 select SalesOrderDetailID,SalesOrderID,CarrierTrackingNumber from AdventureWorks2008R2.Sales.SalesOrderDetail

2.SELECT INTO FROM语句

      语句形式为:SELECT vale1, value2 into Table2 from Table1

      要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中。示例如下:

 --OrderDetail表不存在,当前数据库是TESTDB3
 --从AdventureWorks2008R2的Sales.SalesOrderDetail表获取数据插入到OrderDetail表中
 --只能复制数据,不能复制结构,比如主外键
 select * into OrderDetail from AdventureWorks2008R2.Sales.SalesOrderDetail

 

 

 

 

 

 

 

发表回复