ImageVerifierCode 换一换
格式:DOCX , 页数:6 ,大小:19.40KB ,
资源ID:13159876      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/13159876.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(ABAPSAP报表的性能优化Word文件下载.docx)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

ABAPSAP报表的性能优化Word文件下载.docx

1、比如有一张报表叫做订单状态统计表,可能查完VBAK、VBAP后还查询LIPS、VTTP等,界面上的查询条件很多。不过据了解得知,该报表主要是查看昨天创建或前几天创建的订单。那么最有效的限制条件自然是订单创建日期,以及销售组织了,而表连接的主表宜选用VBAK。(2)确定了表连接的次序后,应考虑将查询条件尽量限制在靠前的表里。比如选择屏幕上有个物料号的查询条件,而我们知道订单VBAP和交货单LIPS均有物料号,那就应该视情况而定,如果表连接中VBAP更早出现,那么WHERE子句中就使用vbapmatnr IN s_matnr,反之就是lipsmatnr IN s_matnr。(3)两个表之间进行连

2、接的时候,应考虑关键字段或索引字段的作用。比如查询VTTP和LIPS时,关联关系是vttpvbeln = lipsvbeln。那么vttp在前,lips在后,就会比较快,因为根据vttp的vbeln查询lips时,vbeln是lips的关键字段,速度较快。而反过来如果lips在前,那根据lipsvbeln查询vttp会慢一些,除非vbeln是vttp的索引字段。2,先构建RANGE再执行SQL语句有时我们所能用的查询条件不是很理想,比如查询LIKP却必须用公司代码,而非销售组织。此时普通做法是用LIKP与TVKO根据VKORG进行表联接,从而限制TVKOBUKRS的值。还有一种有效的办法是,通

3、过TVKO查询到当期公司代码所对应的全部销售组织,从而组建一个RANGE出来,再根据此RANGE查询LIKP。当然要注意RANGE的行项目有上限的,在ECC6中大概2万行将导致ABAP DUMP。提示:DATA r_vkorg TYPE RANGE OF likp-vkorg.SIGN = I, OPTION = EQ, LOW = XXXX即可往r_vkorg中放入多个单值。3,使用COLLECT的注意事项这里把COLLECT单独拎出来,并非排斥对它的使用。事实上COLLECT语句非常好用而且功能强大,却也因此往往被滥用。COLLECT一般是在LOOP循环内被使用,进行汇总运算。对于每个CO

4、LLECT wa INTO it_sum语句,系统会先查找内表it_sum中是否存在相同属性的条目,如果存在则在此条目上对数值进行叠加;如果不存在则新增一个条目。所以,这里涉及了查找的过程,而且该查找动作是在LOOP内进行的,是不是有点类似于嵌套循环?不过,ABAP早考虑到此因素。查看帮助发现,原来此查找过程采用了哈希法,怪不得程序性能依然很好。但是,笔者曾经碰到过一个很慢的报表,仅仅通过对COLLECT语句进行调整,即大大优化了其性能。这是因为该报表没有考虑到以下2点:(1)it_sum中的非数值字段不应过多。上面说了,系统采用哈希法查找it_sum是否存在相同属性的条目。如果非数值字段过多

5、,哈希法的性能将因运算量过大而急速下降。(2)it_sum的最终条目数应该少点。如果条目数增长过快,则查找过程的速度可能将受影响,从而影响性能。比如COLLECT vbak-vkorg可能比COLLECT vbak-vbeln会快些,因为前者的重复性高,结果集的条目数少。4,For All Entries与Select Single的比较就个人而言,笔者不是很喜欢For All Entries语句,因为它的缺点多于优点。很多人都会说,为什么呀,For All Entries不是比Select Single快么?事实到底怎样呢,让我们做个比较。假设我们有个内表代表销售订单的行项目,该内表有10万

6、行。此时我们要根据LIPS的VGBEL和VGPOS,查询这些订单行项目对应的交货单行项目。如果用SELECT SINGLE的话写法很简单:LOOP AT it_vbap INTO wa_vbap.SELECT SINGLE vbeln posnrFROM lips INTO (wa_vbap-vbeln_vl, wa_vbap-posnr_vl)WHERE vgbel = wa_vbap-vbeln ANDvgpos = wa_vbap-posnr ANDvgtyp = C.MODIFY it_vbap FROM wa_vbap.ENDLOOP.如果用For All Entries则写法分2步

7、:SELECT vbeln posnrFROM lips INTO TABLE it_lipsFor All Entries IN it_vbapWHERE vgbel = it_vbap-vbeln ANDvgpos = it_vbap-posnr ANDvgtyp = C. “此交货单是根据订单创建的READ TABLE it_lips INTO wa_lips WITH KEY vgbel = wa_vbap-vbelnvgpos = wa_vbap-vgpos.IF sy-subrc = 0.wa_vbap-vbeln_vl = wa_lips-vbeln.wa_vbap-posnr_

8、vl = wa_lips-posnr.ENDIF.对于SELECT SINGLE而言,由于LIPS有个VGB的SAP自带索引,每次查询都挺快,即便循环10万次,速度虽然快不了但也没什么大的危害。对于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

9、_lips然后才发现没有对应的目标行。所以我们一共需要搜索48亿次,太慢了!在此针对For All Entries的使用提出几点意见:(1)如果是根据某数据量大的内表用For All Entries读取数据量小的配置表,比如TVAK/T006等,那不如把For All Entries直接去掉,把表里的几十条数据全部取出。(2)使用For All Entries时,SELECT语句后面的字段必须包含所查表关键字段。比如上面的vbeln/posnr就是lips的关键字段。如果不含关键字段,比如SELECT lfimg FROM lips For All Entries *,那么当LIPS中两个条目

10、关键字段不同而lfimg相同时,会被SAP自动过滤掉一条。(3)上面关于性能问题,应该利用BINARY SEARCH、SORTED TABLE或者HASHED TABLE来解决。详见下面第四节。5,关于BINARY SEARCH/SORTED TABLE/HASHED TABLE的使用BINARY SEARCH即二分法查找,在保证内表按查询字段以升序排列的时候,可以采用二分法查找。二分法查找的速度很快,最大查询次数为log2n。以上面的例子来说,如果it_lips事先按vgbel和vgpos排好序,则每次查找最多不超过17次。则对于it_vbap的10万个行项目,仅100多万次就可以搞定了!当

11、使用READ TABLE语法时,如果查询字段跟SORTED TABLE的排序开始字段能匹配上,则SAP将自动采用二分法查找。比如it_lips是SORTED TABLE且以vgbel和vgpos排序,则当read table以vgbel进行查找时,系统会自动采用二分法。但如果read table以vgpos和其他字段进行查找,由于vgpos并非SORTED TABLE的第一排序字段,系统将采用直线查找,速度会慢很多。总之,SORTED TABLE的排序字段次序也很关键。针对STANDARD TABLE排序后可以进行二分法查找,使用SORTED TABLE也可进行二分法查找,那么二者有什么区别呢

12、?简单来说,由于SORTED TABLE自始至终都保持排序,如果需要对内部进行频繁的插入、删除操作,则不推荐使用SORTED TABLE,性能会很差。而另一方面,如果我们要用的是类似LOOP AT it_lips WHERE vgbel = *的语法(而非READ TABLE)时,对于STANDARD TABLE就无法采用二分法查找,或者说会很麻烦。而对于SORTED TABLE,系统会自动采用二分法优化查找过程。至于HASHED TABLE,笔者用得也不太多。查看SAP的标准代码,貌似用得也没很多。理论上HASHED TABLE可以比SORTED TABLE更快些,但需要耗用更大的存储空间。

13、当某程序采用了二分法查找之后,如果效果还不是很理想,建议可以用HASHED TABLE试试。6,将循环内的重复性工作进行缓冲有时我们的内表数据量很大,但又不得不在每次循环的时候,都进行类似的一些操作,比如调用函数FI_PERIOD_DETERMINE获取某日期对应的会计年度和期间,调用函数MD_CONVERT_MATERIAL_UNIT进行单位转换,等等。每个函数的调用背后都要执行一系列的读表以及运算工作,程序的效率明显下降了。所以我们得想出有效的办法。比如针对FI_PERIOD_DETERMINE的调用,可以改用循环前对函数G_PERIODS_OF_YEAR_GET的调用。根据公司代码BUK

14、RS读取T001-PERIV,然后调用G_PERIODS_OF_YEAR_GET获取某会计年度每个会计期间对应的起始日期和结束日期。这样在循环内部,只要根据上面的结果即可算出某日期对应的会计年度和期间了。又比如针对MD_CONVERT_MATERIAL_UNIT的调用。相信对于it_vbap的10万个行项目,物料号重复的有很多。所以可以先汇总物料号,然后一次性读取表MARM以存储换算关系。有了MARM的换算关系,循环中大量的单位换算就可以自己算了,如果无法换算的再考虑调用函数MD_CONVERT_MATERIAL_UNIT。(函数MD_CONVERT_MATERIAL_UNIT除了读取MARM的换算关系,还会考虑同一维度单位间的换算关系比如G和KG的关系,所以其功能更强大。)7,关于字段的增强以及TABLE INDEX的创建这里提到字段的增强,主要是性能方面相关的。假设我们需要基于系统所有的billing document做个动作,比如将其导出到金税系统。至少有两种方案:第一是新建一个表,专门记录已经导出到金税的开票

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1