ABAP 性能优化

ABAP程序的性能优化重点:

1、尽量减少读取数据库的次数。减少磁盘I/O次数,避免频繁读取数据表。尤其是在LOOP语句中使用select single 语句,而要把数据放到内表中,再使用read table 语句获取数据;

2、尽量不要使用SELECT * INTO CORESPONDING 语句,减少内存的耗用。更好的办法是select A B into table的语句,因为在执行查询语句时,数据库会查询所有的字段,然后再匹配内表里面的字段。如果是select *,那么会对数据库进行全表扫描,这时候如果再加上关联查询,效率会极低。

3、使用read table 语句的时候,尽可能使用binary search 语句。这个语句固化了二分查找算法,这对匹配数据来说非常有用,我就曾经因为使用了这个语句,把代码执行效率提升了好几倍。当然在使用binary search 语句的时候,要把内表按关键字排序

4、尽量减少inner join的使用,可以把要关联的表放入内表,再使用read table 来匹配数据。因为关联查询的效率是非常低下的,即便一定要关联,也不要超过两个表,我个人推荐只关联两个表,三表关联的话效率就很低了,并且很有可能会导致数据错误;

5、不要使用多重loop语句,提高CPU的效率。也就是不要在loop语句里面嵌套loop语句。这不仅影响效率,对程序可读性也很有影响。

6、尽量用EQ、NE来代替=、<> 等符号。因为用符号的话也会导致读取时效率降低;

7、对业务的更深入了解,可以得到更合理的程序编写和优化能力。在SAP里,要得到一个报表的结果,可能有多种从不同数据表获取的方法,但是有些可能较为曲折和低效,有些则可以提高效率。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值