oracle 向数据库同时插入多条数据

本文对比了Oracle与MySQL在批量插入数据方面的差异,详细介绍了在Oracle中使用UNION ALL和INSERT ALL实现多条数据一次性插入的方法,有效提升数据库操作效率。

 

oracle 与 mysql 不同。

mysql 可以直接插入多条数据的操作;  采用 INSERT INTO 某表 VALUES(各个值),VALUES(各个值),.....; 或者 INSERT INTO VALUEES(各个值),(各个值),(各个值) 。

oracle 不直接支持这种操作,但项目中有时需要一次插入多条数据,多次连接数据库会浪费不少的资源,所以需要变通。

以下是个人总结出两种可以同时插入多条数据到数据库中

insert into 某表(字段1,字段2,字段3...)
(
select 值1,值2,... from dual union all
select 值3,值4,... from dual union all select 各个值 from dual );

 通过 union all 记录合并将结果集插入表中。(union all 比 union 效率快,不检查是否重复)

insert all into 某表 values(各个值) 
into jbbs_group values( 值1,值2,... ) into jbbs_group values( 值3,值4,... ) select 1 from dual;

 

最后一句 select 1 from dual 若是不写会报错。

 

 

工具:PL/SQL Developer

数据库:Oracle10.2.0.3.0

 

如有错误的地方,请指出。谢谢评论。

转载于:https://www.cnblogs.com/mmling/p/8191928.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值