程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> select into 和 insert into select 兩種表復制語句

select into 和 insert into select 兩種表復制語句

編輯:MSSQL

select into 和 insert into select 兩種表復制語句。本站提示廣大學習愛好者:(select into 和 insert into select 兩種表復制語句)文章只能為提供參考,不一定能成為您想要的結果。以下是select into 和 insert into select 兩種表復制語句正文


第一句:SELECT * INTO [ToTable] FROM [FromTable]
第二句:INSERT INTO [ToTable] ([fild_One],[fild_Two]) SELECT [fild_One], 8 FROM [FromTable]

以上兩句都是將 [FromTable] 的數據拔出到 [ToTable],但兩句又有差別的:

第一句(SELECT INTO FROM)請求目的表[ToTable]不存在,由於在拔出時會主動創立。
第二句(INSERT INTO SELECT FROM)請求目的表[ToTable]存在,因為目的表曾經存在,所以我們除拔出源表[FromTable]的字段外,還可以拔出常量,如例中的:8。

Insert是T-sql中經常使用語句,Insert INTO table(field1,field2,...) values(value1,value2,...)這類情勢的在運用法式開辟中必弗成少。但我們在開辟、測試進程中,常常會碰到須要表復制的情形,如將一個table1的數據的部門字段復制到table2中,或許將全部table1復制到table2中,這時候候我們就要應用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 Table1 
( 
a varchar(10), 
b varchar(10), 
c varchar(10), 
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED 
( 
a ASC 
) 
) ON [PRIMARY] 
create TABLE Table2 
( 
a varchar(10), 
c varchar(10), 
d int, 
CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED 
( 
a ASC 
) 
) ON [PRIMARY] 
GO 
--2.創立測試數據 
Insert into Table1 values('趙','asds','90') 
Insert into Table1 values('錢','asds','100') 
Insert into Table1 values('孫','asds','80') 
Insert into Table1 values('李','asds',null) 
GO 
select * from Table2 
--3.INSERT INTO SELECT語句復制表數據 
Insert into Table2(a, c, d) select a,c,5 from Table1 
GO 
--4.顯示更新後的成果 
select * from Table2 
GO 
--5.刪除測試表 
drop TABLE Table1 
drop TABLE Table2 


2.SELECT INTO FROM語句

語句情勢為:SELECT vale1, value2 into Table2 from Table1
請求目的表Table2不存在,由於在拔出時會主動創立表Table2,並將Table1中指定字段數據復制到Table2中。示例以下:

--1.創立測試表 
create TABLE Table1 
( 
a varchar(10), 
b varchar(10), 
c varchar(10), 
CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED 
( 
a ASC 
) 
) ON [PRIMARY] 
GO 
--2.創立測試數據 
Insert into Table1 values('趙','asds','90') 
Insert into Table1 values('錢','asds','100') 
Insert into Table1 values('孫','asds','80') 
Insert into Table1 values('李','asds',null) 
GO 
--3.SELECT INTO FROM語句創立表Table2並復制數據 
select a,c INTO Table2 from Table1 
GO 
--4.顯示更新後的成果 
select * from Table2 
GO 
--5.刪除測試表 
drop TABLE Table1 
drop TABLE Table2 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved