insertintoselect(insert into select语句)

http://www.itjxue.com  2023-01-25 18:03  来源:未知  点击次数: 

Oracle中insert into select和select into的区别

Oracle中insert into select和select into的区别:(select into 就相当于赋值语句,insert into是复制语句),在Oracle中,将一张表的数据复制到另外一个对象中。

通常会有这两种方法:insert into select ?和 select into from。前者可以将select 出来的N行(0到任意数)结果集复制一个新表中,后者只能将"一行"结果复制到一个变量中。这样说吧,select into是PL/SQL language 的赋值语句。而前者是标准的SQL语句。

做一个简单测试,我们就可以很容易地看出两者的差别。

1、首先,我们创建两个表,一个作为源表,一个作为目标表;

create table t_source( ??

id number primary key, ??

testname varchar2(20), ??

createtime date, ??

flag varchar2(10) ??

);

create table t_target( ??

id number primary key, ??

testname varchar2(20), ??

createtime date, ??

flag varchar2(10) ??

);

2、接着,插入测试数据;

insert into t_source values(1,'测试数据1....1',sysdate-2,'N'); ??

insert into t_source values(2,'测试数据1....2',sysdate-2,'N'); ??

insert into t_source values(3,'测试数据1....3',sysdate-2,'N'); ??

commit; ?

测试insert into select 操作

insert into test2 select * from t_source where id=1; ??

commit;

测试select into 操作:

因为select into是一个plsql语言中的复制语句,和:=实现的目标一样。

create or replace procedure sp_sync_test is

aa varchar2(100);

v_record t_source%rowtype; ??

begin

select t1.testname into aa from t_source t1 where id = 1;

dbms_output.put_line('普通变量 t1.testname= ' || aa);

select t1.* into v_record from t_source t1 where id = 1;

dbms_output.put_line('记录变量 t1.testname= ' || v_record.testname);

end;

3、这里增加了原始类型的变量和记录类型的变量,便于大家理解。

甲骨文股份有限公司(Oracle)是全球大型数据库软件公司,总部位于美国加州红木城的红木岸。在2008年,甲骨文股份有限公司是继Microsoft及IBM后,全球收入第三多的软件公司。Oracle数据库产品为财富排行榜上的前1000家公司所采用,许多大型网站也选用了Oracle系统。甲骨文股份有限公司于1989年正式进入中国,在北京、上海、广州和成都均设立了分支机构。

2016年1月,甲骨文表示会收购网站数据追踪服务商AddThis。2016年2月,甲骨文收购了云计算创业公司Ravello Systems。2017年6月7日发布的2017年美国《财富》500强,甲骨文公司排名第81位。2017年6月,《2017年BrandZ最具价值全球品牌100强》公布,甲骨文公司排名第46位。

参考资料

csdn博客.csdn博客[引用时间2018-1-12]

什么是select into from和insert into select?

select into from 和 insert into select都是用来复制表,两者的主要区别为: select into from 要求目标表不存在,因为在插入时会自动创建。insert into select from 要求目标表存在。

备份表数据: create table emp as select * from scott.emp

还原表数据:insert into emp select * from scott.emp

复制表结构及其数据:

create table table_name_new as select * from table_name_old

只复制表结构:

create table table_name_new as select * from table_name_old where 1=2;

或者:

create table table_name_new like table_name_old

只复制表数据:

如果两个表结构一样:

insert into table_name_new?select * from?table_name_old

如果两个表结构不一样:

insert into table_name_new(column1,column2...)?select?column1,column2...

from?table_name_old pasting

select Insert into和Insert into select的区别

insert

into相当于自定义数据数据插入,而insert

into

select则相当于根据其他表的数据插入到被插入的表中。

比如,有如下要被插入的表,表名test

,字段名为id

name

用insert

into的方法

insert into test values (1,'张三')如果用insert

into

select的方法

insert into test select 1,'张三'或者所插入的数据有其他表的来源:

insert into test select id,name from 其他表

(责任编辑:IT教学网)

更多

推荐时间特效文章