SAP BSEG优化问题

        做一个需求,需要取BSEG-XREF1(业务伙伴参考码),并且是批量的取,开始为了省事,所以想着先从BKPF取到会计凭证,公司代码,年度到内表LT_BKPF,然后使用FOR ALL ENTRIES LT_BKPF来从BSEG中得到明细数据, 但由于BSEG 是聚集表,并且数据太大了,所以取数据非常慢,所以想到从BSIS\BSAS,BSIK\BSAK,BSID\BSAD中取数的方法,但这些表中都没有业务伙伴参考码这个字段,所以没得办法,还是只能从BSEG表中想办法,

        后来使用ST05跟踪发现,FOR ALL ENTRIES LT_BKPF在执行时是解析为了多个WHERE 的IN来实现的,最主要的还是一次SELECT只IN有5个值(此值是配置决定的,细节可参看:FOR ALL ENTRIES 优化

所以修改了查询语句修改为(如是HANA数据库请换成:%_HINTS HDB) :

SELECT *
  INTO TABLE LT_BSEG
  FROM BSEG
  FOR ALL ENTRIES IN LT_BKPF
  WHERE BUKRS = LT_BKPF-BUKRS
    AND BELNR = LT_BKPF-BELNR
    AND GJAHR = LT_BKPF-GJAHR
%_HINTS ORACLE
  '&max_blocking_factor 100& &max_in_blocking_factor 1000&'.

后来由于查询条件的一些原因,我觉得修改为如下,可能会更快些,也就是把数据自己先解析为IN,在使用之前先进行排序,这样感觉可能会比标准的更快。

    DATA: II TYPE INT4 ,
          II_MAX TYPE INT4 VALUE 2000.
    LOOP AT LT_BKPF INTO LS_BKPF.
      II = II + 1.
      II_BELNR-SIGN = 'I'.
      II_BELNR-OPTION = 'EQ'.
      II_BELNR-LOW = LS_BKPF-BELNR.
      APPEND II_BELNR.
      IF II > II_MAX.
        SELECT BUKRS
               BELNR
               GJAHR
               BUZEI
               HKONT
               XREF1
               XREF2
               SHKZG
               DMBTR
               WRBTR
          APPENDING TABLE LT_BSEG
          FROM BSEG
          WHERE BUKRS = P_BUKRS
            AND BELNR IN II_BELNR
            AND GJAHR = P_GJAHR .
        II = 0.
        CLEAR:  II_BELNR[].
      ENDIF.

    ENDLOOP.
    IF II_BELNR[] IS NOT INITIAL.
      SELECT BUKRS
             BELNR
             GJAHR
             BUZEI
             HKONT
             XREF1
             XREF2
             SHKZG
             DMBTR
             WRBTR
        APPENDING TABLE LT_BSEG
        FROM BSEG
        WHERE BUKRS = P_BUKRS
          AND BELNR IN II_BELNR
          AND GJAHR = P_GJAHR .
    ENDIF.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ᝰ随心ꦿེএ

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

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

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

打赏作者

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

抵扣说明:

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

余额充值