Oracle实战优化:INSERT ALL关键字的应用

本文介绍了在Oracle数据库中,如何使用INSERT ALL关键字优化大量数据插入的场景,通过实例展示了如何替代循环遍历,提升代码效率和优雅性。利用ROW_NUMBER分析函数控制头表数据插入,有效解决了数据量暴增时程序运行时间过长的问题。
摘要由CSDN通过智能技术生成

原创文章,转载请注明出处,谢谢合作。
https://blog.csdn.net/DarianMograine/article/details/108562035

日前,笔者在优化数据库PROCEDURE的过程中遇到这样一个场景:

DECLARE
  l_header_id NUMBER;

  CURSOR cur_headers IS
    SELECT col1
          ,col2
    FROM   table_a
    WHERE  1 = 1
    AND    xxxx = xxxx;

  CURSOR cur_lines(cp_col1 VARCHAR2
                  ,cp_col2 VARCHAR2) IS
    SELECT b.*
    FROM   table_b
    WHERE  col1 = cp_col1
    AND    col2 = cp_col2;
BEGIN
  FOR rec IN cur_headers LOOP
    l_header_id := xxx_headers_s.nextval;
  
    INSERT INTO header_insert
      (header_id, col1, col2)
    VALUES
      (l_header_id, rec.col1, rec.col2);
  
    FOR line IN cur_lines(rec.col1, rec.col2) LOOP
      INSERT INTO line_insert
        (header_id, line_id, col3, col4, col5, col6)
      VALUES
        (l_header_id
        ,xxx_lines_s.nextval
        ,line.col3
        ,line.col4
        ,line.col5
        ,line
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值