摘记:《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的写法。尽量用对内表的操作来代替对数据库表的操作。