首页 运维知识 关于oracle的批量插入sql

关于oracle的批量插入sql

insert into persons (id_p, lastname , firstName, city ) values (200,\’haha\’ , \’deng\’ , …

insert into persons 
(id_p, lastname , firstName, city )
values
(200,\'haha\' , \'deng\' , \'shenzhen\'),
(201,\'haha2\' , \'deng\' , \'GD\'),
(202,\'haha3\' , \'deng\' , \'Beijing\');

这是mysql的插入语句。
但是我们在oracle中是报错的,语句l

关于oracle的批量插入sql插图

那怎么办呢

也许熟悉oracle数据库的可能知道从oracle9i版本以后,可以使用一种方法即:

“INSERT ALL INTO  a表
VALUES(各个值)
INTO a表 VALUES (其它值)
INTO a表 VALUES(其它值) …. 再跟一个SELECT 语句”。

例如

INSERT
ALL
INTO
d5000.ac_terminal_connect_info
(
id ,
feeder_id,
esn ,
name ,
description
)
VALUES
(
(
select
id
from
d5000.dms_terminal_info
where
esn_id = \’025BHN6RJB504521\’ limit 1
)
,
(
select
feeder_id
from
d5000.dms_terminal_info
where
esn_id = \’025BHN6RJB504521\’ limit 1
)
,
\’025BHN6RJB504521\’,
\’大厂地税局TTU-华为六合管理\’ ,
\’\’
)

INTO
d5000.ac_terminal_connect_info
(
id ,
feeder_id,
esn ,
name ,
description
)
VALUES
(
(
select
id
from
d5000.dms_terminal_info
where
esn_id = \’025BHN6RJB503985\’ limit 1
)
,
(
select
feeder_id
from
d5000.dms_terminal_info
where
esn_id = \’025BHN6RJB503985\’ limit 1
)
,
\’025BHN6RJB503985\’ ,
\’淳溪东甘#3配变TTU-华为高淳管理\’,
\’\’
)
SELECT 1 FROM DUAL

这样就可以啦!显示两条插入成功过。

后边跟的SELECT 语句我们可以从虚拟表里查如 SELECT 1 FROM DUAL。注意后边跟的SELECT语句可以随意,不过不是把它SELECT出来的内容插入前边的表里,而是起到前边的多个数据每次插入多少行的作用,这个多少行是和后边跟的SELECT语句查出来几条而定的,如后边的跟的SELECT 语句查出了15条记录,那么前边的”INSERT ALL INTO  a表 VALUES(各个值1)  INTO a表 VALUES (其它值2) INTO a表 VALUES(其它值3)“就会先插入值1对应的各个字段插入15条记录,然后插入值2各个对应的字段15条记录,然后插入值3对应的各个字段15条记录,也就是说有点按列插入的意思。

我们要的是批量插入多个VALUES这样的一条记录,所以后边的SELECT 语句只要能查出一条记录就行,建议大家后边用SELECT 1 FROM DUAL

免责声明:文章内容不代表本站立场,本站不对其内容的真实性、完整性、准确性给予任何担保、暗示和承诺,仅供读者参考,文章版权归原作者所有。如本文内容影响到您的合法权益(内容、图片等),请及时联系本站,我们会及时删除处理。

作者: 小小编

为您推荐

dell R710 更换raid卡后,raid卡信息没有了,处理方案

dell R710 更换raid卡后,raid卡信息没有了,处理方案

1.将一台服务器(A)的硬盘依次拔出,按相同顺序插入另一台同样配置的服务器(B) 2.启动服务器(B) 3.按提示键盘按...
PL SQL Developer 13连接Oracle数据库并导出数据详细操作教程方法

PL SQL Developer 13连接Oracle数据库并导出数据详细操作教程方法

下载 并安装 PL SQL Developer 13,默认支持中文语言 ========================...
关于一条sql语句在mysql中是如何执行的

关于一条sql语句在mysql中是如何执行的

最近开始在学习mysql相关知识,自己根据学到的知识点,根据自己的理解整理分享出来,本篇文章会分析下一个sql语句在my...
关于sql注入姿势总结(mysql)

关于sql注入姿势总结(mysql)

前言 学习了sql注入很长时间,但是仍然没有系统的了解过,这次总结一波,用作学习的资料。 从注入方法分:基于报错、基于布...
关于Oracle SQL外连接

关于Oracle SQL外连接

SQL提供了多种类型的连接方式,它们之间的区别在于:从相互交叠的不同数据集合中选择用于连接的行时所采用的方法不同。 连接...

发表回复

返回顶部