oracle insert 大数据量的经验

在很多时候,我们会需要对一个表进行插入大量的数据,并且希望在尽可能短的时间内完成该工作,这里,和大家分享下我平时在做大量数据insert的一些经验。

  前提:在做insert数据之前,如果是非生产环境,请将表的索引和约束去掉,待insert完成后再建索引和约束。

  1.


  insert into tab1 select * from tab2; 
  commit;

  这是最基础的insert语句,我们把tab2表中的数据insert到tab1表中。根据经验,千万级的数据可在1小时内完成。但是该方法产生的arch会非常快,需要关注归档的产生量,及时启动备份软件,避免arch目录撑爆。

  2.


  alter table tab1 nologging; 
  insert /*+ append */ into tab1 select * from tab2; 
  commit; 
  alter table tab1 logging;

  该方法会使得产生arch大大减少,并且在一定程度上提高时间,根据经验,千万级的数据可在45分钟内完成。但是请注意,该方法适合单进程的串行方式,如果当有多个进程同时运行时,后发起的进程会有enqueue的等待。注意此方法千万不能dataguard上用(不过要是在database已经force logging那也是不怕的,呵呵)!!

  3.


  insert into tab1 select /*+ parallel */ * from tab2; 
  commit;

  对于select之后的语句是全表扫描的情况,我们可以加parallel的hint来提高其并发,这里需要注意的是最大并发度受到初始化参数parallel_max_servers的限制,并发的进程可以通过v$px_session查看,或者ps -ef |grep ora_p查看。

  4.


  alter session enable parallel dml; 
  insert /*+ parallel */ into tab1 select * from tab2; 
  commit;

  与方法2相反,并发的insert,尚未比较和方法2哪个效率更高(偶估计是方法2快),有测试过的朋友欢迎补充。

  5.


  insert into tab1 select * from tab2 partition (p1); 
  insert into tab1 select * from tab2 partition (p2); 
  insert into tab1 select * from tab2 partition (p3); 
  insert into tab1 select * from tab2 partition (p4);

  对于分区表可以利用tab1进行多个进程的并发insert,分区越多,可以启动的进程越多。我曾经试过insert 2.6亿行记录的一个表,8个分区,8个进程,如果用方法2,单个进程完成可能要40分钟,但是由于是有8个分区8个进程,后发进程有enqueue,所以因此需要的时间为40分钟×8;但是如果用方法5,虽然单个进程需要110分钟,但是由于能够并发进程执行,所以总共需要的时间就约为110分钟了。

  6.


  DECLARE 
  TYPE dtarray IS TABLE OF VARCHAR2(20) INDEX BY BINARY_INTEGER; 
  v_col1 dtarray; 
  v_col2 dtarray; 
  v_col3 dtarray; 
  BEGIN 
  SELECT col1, col2, col3 BULK COLLECT 
  INTO v_col1, v_col2, v_col3 
  FROM tab2; 
  FORALL i IN 1 .. v_col1.COUNT 
  insert into tab1 WHERE tab1.col1 = v_col1; 
  END;

  用批量绑定(bulk binding)的方式。当循环执行一个绑定变量的sql语句时候,在PL/SQL 和SQL引擎(engines)中,会发生大量的上下文切换(context switches)。使用bulk binding,能将数据批量的从plsql引擎传到sql引擎,从而减少上下文切换过程,提升效率。该方法比较适合于在线处理,不必停机。

  7.


  sqlplus -s user/pwd< runlog.txt 
  set copycommit 2; 
  set arraysize 5000; 
  copy from user/pwd@sid - 
  to user/pwd@sid - 
  insert tab1 using select * from tab2; 
  exit 
  EOF

  用copy的方法进行插入,注意此处insert没有into关键字。该方法的好处是可以设置copycommit和arrarysize来一起控制commit的频率,上面的方法是每10000行commit一次。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 这个问题的含义是如何在Oracle中执行大Insert Select操作。答案是可以使用PL/SQL编写脚本来实现。具体的实现方式取决于数据来源和目标表的结构以及要执行的操作。可以使用游标和循环来逐行处理数据,也可以使用Bulk Collect和For All来一次性处理一批数据。同时,可以使用多线程等技术来加速处理速度。总之,需要根据具体情况来选择最佳的实现方式。 ### 回答2: Oracleinsert select语句可以在表之间传递数据,使得数据的插入变得快捷便利。如果需要大插入数据,insert select语句将会派上用场。 首先,insert select语句可以将一张表的数据复制到另一张表中,这种操作对于大数据是非常有用的,因为手动填充数据是耗时且容易出错的。使用insert select语句,程序员可以快速将一张表的数据插入到目标表中。 其次,在大插入数据的情况下,insert select语句具有更高的性能。它可以减少内存和IO的使用,因为它只需要在插入之前从源表中读取数据,这使得插入操作更快。此外,当数据需要转换为另一种格式时,insert select语句可以在源表和目标表之间进行数据转换,因此仍然可以使插入操作变得更加快捷。 最后,insert select语句还可以在插入数据时进行一些额外的检查和计算,例如在插入操作之前可以计算数据的平均值、最大值和最小值等等。这些检查和计算可以使得程序员更容易地获取所需数据,并将数据插入到表中。 综上所述,Oracleinsert select语句可以使插入操作更加快捷且具有更高的性能,对于大数据事务来说是非常有用的。程序员可以在使用时充分利用它们的优点,并确保插入过程不会使系统变得更慢,而是更加高效和快速。 ### 回答3: Oracle数据库中,INSERT SELECT是一种用于将一张表中的数据插入到另一张表中的语句。该方法比单独执行INSERT语句更高效,特别是当需要将大数据从一个表插入到另一个表中时,INSERT SELECT将提供更快的速度和更好的性能。 使用INSERT SELECT可以轻松地将源表的数据插入到目标表中,同时保持数据的完整性。这种方法不仅可以用于将单个记录插入到目标表中,还可以用于将整个查询结果集插入到目标表中。 对于大数据的插入, INSERT SELECT是一个不错的选择。 它允许一次性将大数据移动到目标表中,从而减少了数据移动的次数,降低了数据迁移的时间和资源成本。同时,由于数据的一致性和完整性得到了保证,因此在插入大数据时也可以避免数据丢失或损坏的情况。 除了INSERT SELECT语句之外,还有其他方法可以在Oracle数据库中进行大数据的插入。例如,可以使用批插入技术,将大数据分成小批次进行插入。 这种方法可以进一步提高插入数据的速度和效率,但需要更多的代码实现。 总之,Oracle数据库中,INSERT SELECT是一个常用的方法,用于将大数据从一个表中插入到另一个表中。在插入大数据时,使用INSERT SELECT可以保持数据的完整性和一致性,并提供更快的速度和更好的性能。同时,还可以使用其他方法来进一步提高数据插入的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

河南骏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值