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]不存在,因?yàn)樵诓迦霑r(shí)會(huì)自動(dòng)創(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ā)中必不可少。但我們?cè)陂_發(fā)、測(cè)試過程中,經(jīng)常會(huì)遇到需要表復(fù)制的情況,如將一個(gè)table1的數(shù)據(jù)的部分字段復(fù)制到table2中,或者將整個(gè)table1復(fù)制到table2中,這時(shí)候我們就要使用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)建測(cè)試表 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)建測(cè)試數(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.刪除測(cè)試表 drop TABLE Table1 drop TABLE Table2
2.SELECT INTO FROM語句
語句形式為:SELECT vale1, value2 into Table2 from Table1
要求目標(biāo)表Table2不存在,因?yàn)樵诓迦霑r(shí)會(huì)自動(dòng)創(chuàng)建表Table2,并將Table1中指定字段數(shù)據(jù)復(fù)制到Table2中。示例如下:
--1.創(chuàng)建測(cè)試表 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)建測(cè)試數(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.刪除測(cè)試表 drop TABLE Table1 drop TABLE Table2
相關(guān)文章
SQL?Server數(shù)據(jù)庫創(chuàng)建表及其約束條件的操作方法
這篇文章主要介紹了SQL?Server?創(chuàng)建表及其約束條件,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-11-11分區(qū)表場(chǎng)景下的 SQL 優(yōu)化
這篇文章主要介紹了分區(qū)表場(chǎng)景下的 SQL 優(yōu)化,幫助大家更好的理解和學(xué)習(xí)SQL,感興趣的朋友可以了解下2020-08-08sqlserver下Kill 所有連接到某一數(shù)據(jù)庫的連接
可以通過下面代碼Kill所有連接到某一數(shù)據(jù)庫的所有連接2010-05-05Sqlserver 高并發(fā)和大數(shù)據(jù)存儲(chǔ)方案
本文主要介紹了Sqlserver 高并發(fā)和大數(shù)據(jù)存儲(chǔ)方案。具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01SQL?Server附加數(shù)據(jù)庫報(bào)錯(cuò):無法為該請(qǐng)求檢索數(shù)據(jù)錯(cuò)誤解決辦法
在SQL Server中附加數(shù)據(jù)庫時(shí)可能會(huì)發(fā)生各種錯(cuò)誤,這篇文章主要給大家介紹了關(guān)于SQL?Server附加數(shù)據(jù)庫報(bào)錯(cuò):無法為該請(qǐng)求檢索數(shù)據(jù)錯(cuò)誤的解決辦法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12使用SQL實(shí)現(xiàn)車流量的計(jì)算的示例代碼
本文主要介紹了使用SQL實(shí)現(xiàn)車流量的計(jì)算的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02