首页 > SAP > ABAP > BSEG优化问题
2020
05-20

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) :

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

最后编辑:
作者:yangsen
本站为个人博客网站,全由我个人维护,我从事SAP开发13年,其它ERP开发7年,基本都是零售行业。本站记录工作学习的过程, 有SAP相关询问专、兼职工作可随时联系我。 有网站相关的问题可直接在文章下方留言,或者联系我。 邮件:yan252@163.com给我。 QQ:415402519

留下一个回复

你的email不会被公开。

4 × 3 =