【优化】大数据量内表优化技巧

应用场景:在优化过程中我们经常会碰到处理数据量上百万或者千万大数据内表的情况,本例介绍的是一种通过tabix减少读取数据量的思想。

注意事项: 1、首先需要排序

                      2、先通过二分查找read内表的方式找到我们数据所在的index

                     3、将sy-tabix赋给变量

                     4、通过 loop at itabinto wa_itab from l_v_tabix

                          Endloop,的方式指定读取的开始位置。

  

DATA: l_v_trans_idx  TYPE sy-tabix,
        l_v_trans_idx1 TYPE sy-tabix.

 

 

  SORT l_i_trans BY bukrs kunnr agrid budat DESCENDING.
  LOOP AT l_i_trans ASSIGNING <fs_trans>.
    CLEAR l_v_balance.
    l_v_balance = <fs_trans>-sp_balance.


    READ TABLE fp_i_trans TRANSPORTING NO FIELDS
      WITH KEY bukrs = <fs_trans>-bukrs
               kunnr = <fs_trans>-kunnr
               agrid = <fs_trans>-agrid BINARY SEARCH.
    IF sy-subrc = 0.
      MOVE sy-tabix TO l_v_trans_idx.
      LOOP AT fp_i_trans INTO l_wa_trans FROM l_v_trans_idx.
        IF l_wa_trans-bukrs <> <fs_trans>-bukrs OR
           l_wa_trans-kunnr <> <fs_trans>-kunnr OR
           l_wa_trans-agrid <> <fs_trans>-agrid.
          EXIT.
        ENDIF.

        IF l_wa_trans-budat <= <fs_trans>-budat AND
           l_wa_trans-ttype = c_ttype1 AND
           l_wa_trans-sp_balance > 0.

          l_v_balance = l_v_balance + l_wa_trans-sp_balance.

          IF l_v_balance >= 0.
            l_wa_trans-sp_balance = l_v_balance.
            MODIFY fp_i_trans FROM l_wa_trans.
            EXIT.
          ELSE.
            l_wa_trans-sp_balance = 0.
            MODIFY fp_i_trans FROM l_wa_trans.
          ENDIF.
        ENDIF.
      ENDLOOP.
    ENDIF.

  ENDLOOP.

* 后进后出法对冲负数发放数据
  SORT l_i_trans_ff BY bukrs kunnr agrid budat DESCENDING.
  LOOP AT l_i_trans_ff ASSIGNING <fs_trans>.
    CLEAR l_v_balance.
    l_v_balance = <fs_trans>-ff_balance.

    READ TABLE fp_i_trans TRANSPORTING NO FIELDS
      WITH KEY bukrs = <fs_trans>-bukrs
               kunnr = <fs_trans>-kunnr
               agrid = <fs_trans>-agrid BINARY SEARCH.
    IF sy-subrc = 0.
      MOVE sy-tabix TO l_v_trans_idx1.
      LOOP AT fp_i_trans INTO l_wa_trans FROM l_v_trans_idx1.
        IF l_wa_trans-bukrs <> <fs_trans>-bukrs OR
           l_wa_trans-kunnr <> <fs_trans>-kunnr OR
           l_wa_trans-agrid <> <fs_trans>-agrid.
          EXIT.
        ENDIF.

        IF l_wa_trans-budat <= <fs_trans>-budat AND
           l_wa_trans-ttype <> c_ttype1 AND
           l_wa_trans-ff_balance > 0.

          l_v_balance = l_v_balance + l_wa_trans-ff_balance.
          IF l_v_balance >= 0.
            l_wa_trans-ff_balance = l_v_balance.
            MODIFY fp_i_trans FROM l_wa_trans.
            EXIT.
          ELSE.
            l_wa_trans-ff_balance = 0.
            MODIFY fp_i_trans FROM l_wa_trans.
          ENDIF.
        ENDIF.
      ENDLOOP.
    ENDIF.

  ENDLOOP.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值