当前位置: 首页 > news >正文

[SAP ABAP] 性能优化

1.数据库编程OPEN SQL方面优化

1.避免使用SELECT *,只查询需要的字段即可

尽量使用SELECT f1 f2 ... (具体字段) 来代替 SELECT * 写法

2. 如果确定只查询一条数据时,使用 SELECT SINGLE... 或者是 SELECT ...UP TO 1 ROWS ...

使用语法 UP TO n ROWS 来实现对数据前n项的查询

3. 统计时,直接使用SQL聚合函数,而不是将数据读取出来后在程序里再进行统计 

充分利用系统提供的标准函数,如max,min,sum,count,avg等

4.少用嵌套SELECT … ENDSELECT,可以使用联合查询 或 FOR ALL ENTRIES来替换,减少循环次数

5.在SELECT语句中使用 INNER JOIN 语句可以实现一次性查询得到匹配的数据

6.在SELECT语句中使用WHERE子句来限制数据检索的体积

尽量多添加WHERE检索条件进行条件抽取

WHERE语句中尽量避免使用 < 、 > 等模糊条件进行查询

7.避免使用嵌套的SELECT语句,以及在LOOP循环中使用SELECT语句

8.避免多次运行相同的SELECT(同样的SELECT,同样的查询参数)

9.对于需要同时对多个表进行数据查询时,尽量使用JOIN语句,且注意应该选择数据量最小的表作为基表,尽量避免3个以上的表进行JOIN查询

10.尽量不要在频率较高的循环语句中使用UPDATE、INSERT、DELETE、MODIFY等操作

2.内表方面优化

1.使用binary search二分法查询,提高查询内表数据速度

READ TABLE 之前使用 SORT TABLE BY 对内表进行排序,然后使用READ TABLE WITH KEY ...BINARY SEARCH.

2.尽可能使用哈希表(Hash表),其次是排序表(Sort表),最后是标准表(Standard表)

补充扩展

我们可以使用事务码SE30、ST12ST05进行程序和SQL语句性能和效率的分析

http://www.lryc.cn/news/531247.html

相关文章:

  • 并行计算、分布式计算与云计算:概念剖析与对比研究(表格对比)
  • ASP.NET Core Filter
  • doris:删除操作概述
  • 【思维导图】redis
  • 申博经验贴
  • .Net Core笔记知识点(跨域、缓存)
  • YOLOV11-1:YoloV11-安装和CLI方式训练模型
  • 自学习记录-编程语言的特点(持续记录)
  • TypeScript (TS) 和 JavaScript (JS)
  • 【HarmonyOS之旅】基于ArkTS开发(二) -> UI开发三
  • 如何选择Spring AOP的动态代理?JDK与CGLIB的适用场景?
  • 手机连接WIFI可以上网,笔记本电脑连接WIFI却不能上网? 解决方法?
  • MySQL不适合创建索引的11种情况
  • 树莓派pico入坑笔记,故障解决:请求 USB 设备描述符失败,故障码(43)
  • GRE阅读双线阅读 --青山学堂GRE全程班 包括 阅读、数学、写作、填空、背单词
  • 98,【6】 buuctf web [ISITDTU 2019]EasyPHP
  • Kamailio、MySQL、Redis、Gin后端、Vue.js前端等基于容器化部署
  • 知识管理系统助力企业信息共享与创新思维的全面提升研究
  • Leetcode 131 分割回文串(纯DFS)
  • 结构体DMA串口接收比特错位
  • 用FormLinker实现自动调整数据格式,批量导入微软表单
  • 技术架构师成长路线(2025版)
  • 独立开发者的技术栈
  • wordpress每隔24小时 随机推荐一个指定分类下的置顶内容。
  • Android13源码下载和编译过程详解
  • C++底层学习预备:模板初阶
  • 使用mybatisPlus插件生成代码步骤及注意事项
  • 扩散模型(二)
  • java异常处理——try catch finally
  • 新月军事战略分析系统使用手册