《报表性能优化》PPT课件.ppt
《《报表性能优化》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《报表性能优化》PPT课件.ppt(12页珍藏版)》请在三一办公上搜索。
1、ABAP:SAP报表的性能优化,1、关于表连接语句(INNER JOIN,LEFT JOIN.)写报表的时候,表与表之间的关联是不可避免的。通常而言,表连接语句要掌握的原则有:(1)将最有效的查询条件所对应的表放在第一位。换言之,让查询第一个表后所得到的结果集就尽可能小。比如有一张报表叫做订单状态统计表,可能查完VBAK、VBAP后还查询LIPS、VTTP等,界面上的查询条件很多。不过据了解得知,该报表主要是查看昨天创建或前几天创建的订单。那么最有效的限制条件自然是订单创建日期,以及销售组织了,而表连接的主表宜选用VBAK。(2)确定了表连接的次序后,应考虑将查询条件尽量限制在靠前的表里。比如
2、选择屏幕上有个物料号的查询条件,而我们知道订单VBAP和交货单LIPS均有物料号,那就应该视情况而定,如果表连接中VBAP更早出现,那么WHERE子句中就使用vbapmatnr IN s_matnr,反之就是lipsmatnr IN s_matnr。(3)两个表之间进行连接的时候,应考虑关键字段或索引字段的作用。比如查询VTTP和LIPS时,关联关系是vttpvbeln=lipsvbeln。那么vttp在前,lips在后,就会比较快,因为根据vttp的vbeln查询lips时,vbeln是lips的关键字段,速度较快。而反过来如果lips在前,那根据lipsvbeln查询vttp会慢一些,除非
3、vbeln是vttp的索引字段。,2,先构建RANGE再执行SQL语句有时我们所能用的查询条件不是很理想,比如查询LIKP却必须用公司代码,而非销售组织。此时普通做法是用LIKP与TVKO根据VKORG进行表联接,从而限制TVKOBUKRS的值。还有一种有效的办法是,通过TVKO查询到当期公司代码所对应的全部销售组织,从而组建一个RANGE出来,再根据此RANGE查询LIKP。当然要注意RANGE的行项目有上限的,在ECC6中大概2万行将导致ABAP DUMP。提示:DATA r_vkorgTYPERANGEOF likp-vkorg.SIGN=I,OPTION=EQ,LOW=XXXX即可往r
4、_vkorg中放入多个单值。,3,For All Entries与Select Single的比较就个人而言,笔者不是很喜欢For All Entries语句,因为它的缺点多于优点。很多人都会说,为什么呀,For All Entries不是比Select Single快么?事实到底怎样呢,让我们做个比较。假设我们有个内表代表销售订单的行项目,该内表有10万行。此时我们要根据LIPS的VGBEL和VGPOS,查询这些订单行项目对应的交货单行项目。,ENDLOOP.对于SELECT SINGLE而言,由于LIPS有个VGB的SAP自带索引,每次查询都挺快,即便循环10万次,速度虽然快不了但也没什么
5、大的危害。对于For All Entries的第一步,的确比SELECT SINGLE快些,本来10万次的SELECT SINGLE,变成了1万次的查询(如果BASIS设置了参数为10),每次查询10个订单行项目。但是第二步就很慢了,暂估it_lips为8万行,则对于it_vbap的10万个行项目,有8万个行项目执行READ TABLE语句平均需要4万次才能搜索到it_lips的目标行,另有2万个行项目将读遍it_lips然后才发现没有对应的目标行。所以我们一共需要搜索48亿次,太慢了!在此针对For All Entries的使用提出几点意见:(1)如果是根据某数据量大的内表用For All
6、Entries读取数据量小的配置表,比如TVAK/T006等,那不如把For All Entries直接去掉,把表里的几十条数据全部取出。,(2)使用For All Entries时,SELECT语句后面的字段必须包含所查表关键字段。比如上面的vbeln/posnr就是lips的关键字段。如果不含关键字段,比如SELECT lfimg FROM lips For All Entries*,那么当LIPS中两个条目关键字段不同而lfimg相同时,会被SAP自动过滤掉一条。(3)上面关于性能问题,应该利用BINARY SEARCH、SORTED TABLE或者HASHED TABLE来解决。详见下
7、面第四节。4,关于BINARY SEARCH/SORTED TABLE/HASHED TABLE的使用BINARY SEARCH即二分法查找,在保证内表按查询字段以升序排列的时候,可以采用二分法查找。二分法查找的速度很快,最大查询次数为log2n。以上面的例子来说,如果it_lips事先按vgbel和vgpos排好序,则每次查找最多不超过17次。则对于it_vbap的10万个行项目,仅100多万次就可以搞定了!当使用READ TABLE语法时,如果查询字段跟SORTED TABLE的排序开始字段能匹配上,则SAP将自动采用二分法查找。比如it_lips是SORTED TABLE且以vgbel和
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 报表性能优化 报表 性能 优化 PPT 课件

链接地址:https://www.31ppt.com/p-5515520.html