摘记-ABAP程序的代码编写技巧及注意事项

摘记:《SAP实用程序开发进阶》

4.7.1 内表、字符串及循环的处理
  • 在结构相同的内表间赋值时,可以直接通过APPEND <内表1> TO <内表2>来提高效率。
    例如:
    TAB2 = TAB1.
    APPEND TAB2.
    可优化为:
    APPEND TAB2 TO TAB1.
  • 读取内表时加上扩展语句BINARY SEARCH(二分法检索)。
    例如:
    READ TABLE TAB1 WITH KEY ID = ‘01’ BINARY SEARCH.
  • 通过LOOP语句循环读取内表时,可以根据数据需求加上WHERE条件。
  • 通过MODIFY语句更新内表时,加上TRANSPONDING(转接)以指定更新字段。
  • 通过LOOP语句循环读取内表时,可以考虑通过指针方式来更新内表字段值,减少MODIFY操作,如下例所示。
    LOOP AT itab ASSINGING .
    -flag = ‘A’.
    ENDLOOP.
  • 对内表数值类型的字段进行汇总时通过COLLECT来实现。
    LOOP AT ITAB1.
    COLLECT ITAB1 INTO ITAB2.
    ENDLOOP.
  • 相同结构的内表间赋值时可以直接拷贝,如:TAB1[] = TAB2[]。
  • 对内表进行排序时最好能加上关键值字段。
  • 当需要对变量的值进行条件判断,可以考虑使用CASE…ENDCASE的方法。
  • 进行算术计算的字段最好使用系统的类型,如下图所示。
    DATA:p1 TYPE p,
    p2 TYPE p,
    p3 TYPE p.
    p3 = p1 * p2.
4.7.2 Open SQL编写中的注意事项

sql语句语法是否合理,直接影响程序的执行效率,编写Open SQL时,应注意以下几点。

  • 要充分利用INDEX,且INDEX的栏位要尽量同时使用,如下图所示。
    SELECT * FROM spfli
    WHERE carrid = ‘LH’ AND connid = ‘0455’.
  • 要尽量使用SELECT f1 f2 …(具体栏位)来代替SELECT *写法。
  • 不要使用check语句对Ttable进行条件查询,用where语句代替。
  • 使用语法up to n rows来实现对数据前n项的查询。
  • 充分利用系统提供的标准函数,如:max,min,avg,sum,count等。
  • 尽量不要在频率较高的循环语句中使用UPDATE、INSERT、 DELETE 、MODIFY等操作。
  • 对于需要同时对多个表数据查询时,尽量使用JOIN语句,且注意应选择资料量最小的表作为基表,尽量避免三个以上table间的相关join查询。
  • 在查询单条数据时,尽量使用SELECT SINGLE语句,不要使用SELECT…ENDSELECT语句。
  • 对于存在OR条件判断的语句,尽量使用IN来代替。
  • where语句中尽量避免使用“<”、">"等模糊条件进行查询。
  • 在对内表赋值的时候,尽量使用select…into…table的写法来代替select…append table …endselect的写法。尽量用对内表的操作来代替对数据库表的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值