select into 和 insert into select 兩種表復(fù)制語句
第一句:SELECT * INTO [ToTable] FROM [FromTable]
第二句:INSERT INTO [ToTable] ([fild_One],[fild_Two]) SELECT [fild_One], 8 FROM [FromTable]
以上兩句都是將 [FromTable] 的數(shù)據(jù)插入到 [ToTable],但兩句又有區(qū)別的:
第一句(SELECT INTO FROM)要求目標(biāo)表[ToTable]不存在,因為在插入時會自動創(chuàng)建。
第二句(INSERT INTO SELECT FROM)要求目標(biāo)表[ToTable]存在,由于目標(biāo)表已經(jīng)存在,所以我們除了插入源表[FromTable]的字段外,還可以插入常量,如例中的:8。
Insert是T-sql中常用語句,Insert INTO table(field1,field2,...) values(value1,value2,...)這種形式的在應(yīng)用程序開發(fā)中必不可少。但我們在開發(fā)、測試過程中,經(jīng)常會遇到需要表復(fù)制的情況,如將一個table1的數(shù)據(jù)的部分字段復(fù)制到table2中,或者將整個table1復(fù)制到table2中,這時候我們就要使用SELECT INTO 和 INSERT INTO SELECT 表復(fù)制語句了。
1.INSERT INTO SELECT語句
語句形式為:Insert into Table2(field1,field2,...) select value1,value2,... from Table1
要求目標(biāo)表Table2必須存在,由于目標(biāo)表Table2已經(jīng)存在,所以我們除了插入源表Table1的字段外,還可以插入常量。示例如下:
--1.創(chuàng)建測試表 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.創(chuàng)建測試數(shù)據(jù) 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語句復(fù)制表數(shù)據(jù) Insert into Table2(a, c, d) select a,c,5 from Table1 GO --4.顯示更新后的結(jié)果 select * from Table2 GO --5.刪除測試表 drop TABLE Table1 drop TABLE Table2
2.SELECT INTO FROM語句
語句形式為:SELECT vale1, value2 into Table2 from Table1
要求目標(biāo)表Table2不存在,因為在插入時會自動創(chuàng)建表Table2,并將Table1中指定字段數(shù)據(jù)復(fù)制到Table2中。示例如下:
--1.創(chuàng)建測試表 create TABLE Table1 ( a varchar(10), b varchar(10), c varchar(10), CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED ( a ASC ) ) ON [PRIMARY] GO --2.創(chuàng)建測試數(shù)據(jù) 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語句創(chuàng)建表Table2并復(fù)制數(shù)據(jù) select a,c INTO Table2 from Table1 GO --4.顯示更新后的結(jié)果 select * from Table2 GO --5.刪除測試表 drop TABLE Table1 drop TABLE Table2
相關(guān)文章
SQL?Server數(shù)據(jù)庫創(chuàng)建表及其約束條件的操作方法
這篇文章主要介紹了SQL?Server?創(chuàng)建表及其約束條件,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-11-11sqlserver下Kill 所有連接到某一數(shù)據(jù)庫的連接
可以通過下面代碼Kill所有連接到某一數(shù)據(jù)庫的所有連接2010-05-05Sqlserver 高并發(fā)和大數(shù)據(jù)存儲方案
本文主要介紹了Sqlserver 高并發(fā)和大數(shù)據(jù)存儲方案。具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01SQL?Server附加數(shù)據(jù)庫報錯:無法為該請求檢索數(shù)據(jù)錯誤解決辦法
在SQL Server中附加數(shù)據(jù)庫時可能會發(fā)生各種錯誤,這篇文章主要給大家介紹了關(guān)于SQL?Server附加數(shù)據(jù)庫報錯:無法為該請求檢索數(shù)據(jù)錯誤的解決辦法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12