Topic: ABAP程序的性能优化

ERP俱乐部

第 1 页 总共 1 页 [共有 4 条记录]


Posted by tr on 2012-11-15 02:57 下午
ABAP程序的性能优化有几点非常重要。
       第一,我们要尽可能的减少读取数据库的次数,尤其是在LOOP语句中使用select single 语句,而要把数据放到内表中,再使用read table 语句获取数据;
       第二,尽可能不要使用SELECT * INTO CORESPONDING 语句,更好的办法是select A B into table的语句,因为在执行查询语句时,数据库会查询所有的字段,然后再匹配内表里面的字段。如果是select *,那么会对数据库进行全表扫描,这时候如果再遇到关联查询,效率可想而知。
      第三,使用read table 语句的时候,尽可能使用binary search 语句,这个语句固化了二分查找算法,这对匹配数据来说非常有用,我就曾经因为使用了这个语句,把代码执行效率提升了好几倍。当然在使用binary search 语句的时候,要把内表按关键字排序。其实排序是个非常好的习惯;
      第四,尽可能减少inner join的使用,可以把要关联的表放入内表,再使用read table 来匹配数据,因为关联查询的效率是非常低下的,即便一定要关联,也不要超过两个表,我个人推荐只关联两个表,三表关联的话效率就很低了,并且很有可能会导 致数据错误;
      第五,不要使用多重loop语句,也就是不要在loop语句里面嵌套loop语句。这不仅影响效率,对程序可读性也很有影响。
      第六,是关于符号的,这点可能注意的人比较少,尽可能用EQ、NE来代替=、<> 等符号,因为用符号的话也会导致读取时效率降低;
      第七,使用索引。这个一般都会用到,这里只是说一句,簇表不能加索引。
      因为ABAP语言是解释型的程序设计语言,所以在执行上先天就比较慢,这就要求ABAP顾问对程序性能要比较好的优化,因为超时这种事,谁都不愿意看到。

Posted by kitty on 2012-11-16 09:50 上午

谢谢分享。


Posted by wang2 on 2012-11-19 07:22 下午
就个人经验而言,第一点的重要性远远高于其他。

Posted by summerlan on 2013-09-09 09:10 上午
谢谢分享。