今天做一个需求,需要取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) :
1 2 3 4 5 6 7 8 9 |
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,在使用之前先进行排序,这样感觉可能会比标准的更快。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 |
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. |