最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

selectinto和insertintoselect全表复制sql语句

来源:动视网 责编:小采 时间:2020-11-09 09:57:54
文档

selectinto和insertintoselect全表复制sql语句

selectinto和insertintoselect全表复制sql语句:select into 和 insert into select 全表复制sql语句 有需要的朋友可参考一下。 Insert是T-sql中常用语句,Insert INTO table(field1,field2...) values(value1,value2...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中
推荐度:
导读selectinto和insertintoselect全表复制sql语句:select into 和 insert into select 全表复制sql语句 有需要的朋友可参考一下。 Insert是T-sql中常用语句,Insert INTO table(field1,field2...) values(value1,value2...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中


select into 和 insert into select 全表复制sql语句 有需要的朋友可参考一下。

Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中,经常会遇到需要表复制的情况,如将 一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了。

区别

代码如下

select * into destTbl from srcTbl

insert into destTbl(fld1, fld2) select fld1, 5 from srcTbl

以上两句都是将 srcTbl 的数据插入到 destTbl,但两句又有区别的。

第一句(select into from)要求目标表(destTbl)不存在,因为在插入时会自动创建。

第二句(insert into select from)要求目标表(destTbl)存在,由于目标表已经存在,所以我们除了插入源表(srcTbl)的字段外,还可以插入常量


1.INSERT INTO SELECT语句

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

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

代码如下

CREATE PROC getBusinessLineHistory
AS
BEGIN
SELECT * FROM sys.databases
END
GO

sp_configure 'Show Advanced Options', 1
GO
RECONFIGURE
GO
sp_configure 'Ad Hoc Distributed Queries', 1
GO
RECONFIGURE
GO

SELECT * INTO #MyTempTable FROM OPENROWSET('SQLNCLI', 'Server=(local)SQL2008;Trusted_Connection=yes;',
'EXEC getBusinessLineHistory')

SELECT * FROM #MyTempTable


INSERT INTO SELECT语句复制表数据

2.SELECT INTO FROM语句

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

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

SELECT INTO FROM创建表并复制表数据

代码如下

--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

注意

表中没有记录返回时出错,表中有多条记录返回时也出错,用异常保护。

代码如下

declare
jobid integer;
begin
begin
select job into jobid from all_jobs where what='testjob';
exception
when others then
jobid:=' '; --给一个指定值
end;
end;

同时给多个变量赋值没有问题:

select 字段1,字段2,字段3 into 变量1,变量2,变量3 from 表名 where...

文档

selectinto和insertintoselect全表复制sql语句

selectinto和insertintoselect全表复制sql语句:select into 和 insert into select 全表复制sql语句 有需要的朋友可参考一下。 Insert是T-sql中常用语句,Insert INTO table(field1,field2...) values(value1,value2...)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中
推荐度:
标签: sql 语句 select
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top