insertintoselect,insertintoselect分页

http://www.itjxue.com  2023-01-05 01:17  来源:未知  点击次数: 

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?其他表

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]

SQL insert into select 语句 需要一次插多条

insert into select

语句功能是从一个表格中读取数据,插入另一个表格。

所以,select 子句的结果集是多条记录,那插入的就是多条。

例 :insert into table_b(a,b) select a,b from table_a;

如果table_a中有多条记录,那都会一起插入 table_b中。

insert into select 可以加where条件么

可以加

例:

insert?into?[表名]([列名1],[列名2],[列名3],...)

select?[列名1],[列名2],[列名3],...?from??[表名2]?

where?[条件]

“INSERT INTO SELECT FROM ”这短语怎么用?

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

(责任编辑:IT教学网)

更多