ERP俱乐部
ERP爱好者、ERP从业者互相交流、互相学习的乐园;我们的愿景是成为全球一流的中文ERP(Enterprise Resource Planning)交流平台
网站首页
论坛首页
搜索
用户列表
FAQ
注册
登录
ERP俱乐部
->
SAP专栏
->
ABAP
->
Re: ABAP程序的性能优化
Re: ABAP程序的性能优化
帖子发起人:
tr
发起时间:
2012-11-15 02:57 下午
回复数:
3
楼主
2012-11-15, 02:57 下午
tr
等级: 80级
注册: 2011年1月4日
经验: 1,658
积分: 1,598
精华: 0
发贴: 74
排名: 20
ABAP程序的性能优化
ABAP程序的性能优化有几点非常重要。
第一,我们要尽可能的减少读取数据库的次数,尤其是在LOOP语句中使用select single 语句,而要把数据放到内表中,再使用read table 语句获取数据;
第二,尽可能不要使用SELECT * INTO CORESPONDING 语句,更好的办法是select A B into table的语句,因为在执行查询语句时,数据库会查询所有的字段,然后再匹配内表里面的字段。如果是select *,那么会对数据库进行全表扫描,这时候如果再遇到关联查询,效率可想而知。
第三,使用read table 语句的时候,尽可能使用
bi
nary search 语句,这个语句固化了二分查找算法,这对匹配数据来说非常有用,我就曾经因为使用了这个语句,把代码执行效率提升了好几倍。当然在使用binary search 语句的时候,要把内表按关键字排序。其实排序是个非常好的习惯;
第四,尽可能减少inner join的使用,可以把要关联的表放入内表,再使用read table 来匹配数据,因为关联查询的效率是非常低下的,即便一定要关联,也不要超过两个表,我个人推荐只关联两个表,三表关联的话效率就很低了,并且很有可能会导 致数据错误;
第五,不要使用多重loop语句,也就是不要在loop语句里面嵌套loop语句。这不仅影响效率,对程序可读性也很有影响。
第六,是关于符号的,这点可能注意的人比较少,尽可能用EQ、NE来代替=、<> 等符号,因为用符号的话也会导致读取时效率降低;
第七,使用索引。这个一般都会用到,这里只是说一句,簇表不能加索引。
因为ABAP语言是解释型的程序设计语言,所以在执行上先天就比较慢,这就要求ABAP顾问对程序性能要比较好的优化,因为超时这种事,谁都不愿意看到。
分享按钮
IP 地址: 已登录 来自: 已登录
第 2 楼
2012-11-16, 09:50 上午
kitty
职务: 超级管理员
等级: 90级
注册: 2004年9月7日
区域: 深圳
经验: 3,483
积分: 5,947
精华: 0
发贴: 2,176
排名: 10
Re: ABAP程序的性能优化
谢谢分享。
Kitty,ERPCLUB TEAM
You ok,so we ok
email:tm@yok.com.cn
MSN:kitty_mtang@hotmail.com
我的博客:http://www.erpclub.org/blog/kitty/
IP 地址: 已登录 来自: 已登录
第 3 楼
2012-11-19, 07:22 下午
wang2
等级: 20级
注册: 2012年11月16日
区域: 深圳
经验: 24
积分: 24
精华: 0
发贴: 11
排名: 1,164
Re: ABAP程序的性能优化
就个人经验而言,第一点的重要性远远高于其他。
分享按钮
IP 地址: 已登录 来自: 已登录
第 4 楼
2013-09-09, 09:10 上午
summerlan
等级: 70级
注册: 2013年5月17日
经验: 501
积分: 642
精华: 0
发贴: 381
排名: 52
Re: ABAP程序的性能优化
谢谢分享。
来Yok !
You ok,so we ok
email:cuiqin.lan@yok.com.cn
tel:0755-26523860; 18038036868
MSN:yoksaphunter@hotmail.com
QQ:374439400
请关注亚可官方微博:
亚可YOK 、sapclub
IP 地址: 已登录 来自: 已登录
第 1 页 总共 1 页 [共有 4 条记录]
ERP俱乐部
->
SAP专栏
->
ABAP
->
Re: ABAP程序的性能优化
请选择
论坛首页
─» 论坛搜索
─» 最新主题
─» 热门主题
─» 未回复的主题
用户选项
─» 登陆
─» 注册
─» 找回密码
SAP专栏
─» FI&CO(财务与会计)
─» MM(物料管理)
─» SD(销售与分销)
─» PP(生产计划)
─» WM、LE(物流、仓库、发运)
─» QM(质量管理)
─» PS(项目系统)
─» PM(工厂维护)
─» HR(人力资源)
─» BASIS
─» ABAP
─» SAP Business Intelligence(数据仓库)
─» SAP BUSINESS ONE
─» SAP Netweaver
─» SAP Solutions
─» CRM(Customer Relationship Management客户关系管理)
─» Workflow
─» SAP综合讨论版块
─» HANA(High-Performance Analytic Appliance)
Oracle Applications专栏
─» Oracle E-Business Suite
─» PeopleSoft Enterprise
─» Siebel
─» JD Edwards
─» Hyperion
Microsoft专栏
─» 亚可审批工作流、CRM专栏
─» Visual C#
─» ASP.NET
UFIDA专栏
─» 用友
Kingdee专栏
─» 金蝶
数据库专栏
─» Oracle数据库
─» Oracle入门与认证
─» Oracle开发
─» MS SQL Server数据库
─» DB2数据库
会员交流
─» 培训专栏
─» 休闲与娱乐
─» 招聘与求职
─» SAP新闻
─» 供求专区
─» 海阔天空
信息化建设讨论组
─» PLM
─» IT规划及CIO
─» ERP
─» 数据仓库与数据挖掘
管理员及版主
─» 问题报告
站务管理
─» 站点公告及意见建议
(C)Copyright 2005-2020
www.erpclub.org
All Rights Reserved.
Tel:+86-755-26444630
Email:webmaster@yok.com.cn