select into 和 insert into select 兩種表復(fù)制語(yǔ)句
第一句: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中常用語(yǔ)句,Insert INTO table(field1,field2,...) values(value1,value2,...)這種形式的在應(yīng)用程序開(kāi)發(fā)中必不可少。但我們?cè)陂_(kāi)發(fā)、測(cè)試過(guò)程中,經(jīng)常會(huì)遇到需要表復(fù)制的情況,如將一個(gè)table1的數(shù)據(jù)的部分字段復(fù)制到table2中,或者將整個(gè)table1復(fù)制到table2中,這時(shí)候我們就要使用SELECT INTO 和 INSERT INTO SELECT 表復(fù)制語(yǔ)句了。
1.INSERT INTO SELECT語(yǔ)句
語(yǔ)句形式為: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('錢(qián)','asds','100') Insert into Table1 values('孫','asds','80') Insert into Table1 values('李','asds',null) GO select * from Table2 --3.INSERT INTO SELECT語(yǔ)句復(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語(yǔ)句
語(yǔ)句形式為: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('錢(qián)','asds','100') Insert into Table1 values('孫','asds','80') Insert into Table1 values('李','asds',null) GO --3.SELECT INTO FROM語(yǔ)句創(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
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。