SAP内表查询速度优化实例-OPEN SQL
一、FOR ALL ENTRIES IN 案例
今天碰到工单报工统计分析表查询速度特别慢
经查看源代码:
SELECT afpo~dwerk afko~aufnr afpo~matnr AS plnbez afpo~charg afpo~psmng afko~fevor afko~aufpl
FROM afko INNER JOIN afpo
ON afko~aufnr = afpo~aufnr
INTO CORRESPONDING FIELDS OF TABLE it_afpo
WHERE afpo~dwerk = p_dwerk
AND afpo~aufnr IN p_aufnr
AND afpo~matnr IN p_matnr
AND afko~fevor IN p_fevor
AND afpo~charg IN p_charg.
IF f_wr = 'X'.
SELECT *
FROM afru
INTO CORRESPONDING FIELDS OF TABLE it_afru
FOR ALL ENTRIES IN it_afpo
WHERE werks = it_afpo-dwerk
AND aufnr = it_afpo-aufnr
AND ersda IN p_ersda
AND prdut IN p_prdut
AND stokz <> 'X'
AND stzhl = 0 .
ELSE.
SELECT *
FROM afru
INTO CORRESPONDING FIELDS OF TABLE it_afru
FOR ALL ENTRIES IN it_afpo
WHERE werks = it_afpo-dwerk
AND aufnr = it_afpo-aufnr
AND ersda IN p_ersda
AND prdut IN p_prdut.
ENDIF.
FOR ALL ENTRIES IN 使用前需判断后面的内表是否为空,为空则查询出的数据特别多,影响查询速度,如内表数据量很大,速度也很慢。
这样就是 FOR ALL ENTRIES IN 后面内表的数据量很大。一年的工单有一万多条。
所以这里,不使用FOR ALL ENTRIES IN语句。
解决方法:
1、where语句in该内表,定义range类型内表:it_aufnr 存储 it_afpo-aufnr 数据。
RANGES: it_aufnr FOR afko-aufnr.
LOOP AT it_afpo.
it_aufnr-low = it_afpo-aufnr.
it_aufnr-sign = 'I'.
it_aufnr-option = 'EQ'.
APPEND it_aufnr.
ENDLOOP.
也可以查询it_afpo的时候就直接赋值给it_aufnr
例:(查询出的数据要用low,需要定义sign和option)
SELECT aufnr INTO it_aufnr-low FROM afko WHERE dwerk = p_dwerk AND gltri IN p_ersda.
it_matnr-sign = 'I'.
it_matnr-option = 'EQ'.
APPEND it_matnr.
ENDSELECT.
IF NOT it_aufnr[] IS INITIAL.
SELECT * INTO CORRESPONDING FIELDS OF TABLE it_afru
FROM afko WHERE dwerk = p_dwerk AND ersda IN p_ersda AND aufnr IN it_aufnr
AND prdut IN p_prdut AND stokz <> 'X' AND stzhl = 0 .
也可以这样写:
append it_aufnr to it_aufnr[].
WHERE aufnr IN it_aufnr[].
2、loop 循环 it_afru 内表,删除 it_afpo 中不存在的 aufnr 行。
SELECT * FROM afru
INTO CORRESPONDING FIELDS OF TABLE it_afru
* FOR ALL ENTRIES IN it_afpo
WHERE werks = p_dwerk
* AND aufnr = it_afpo-aufnr
AND ersda IN p_ersda
AND prdut IN p_prdut
AND stokz <> 'X'
AND stzhl = 0 .
IF NOT it_afru[] IS INITIAL.
LOOP AT it_afru .
READ TABLE it_afpo WITH KEY aufnr = it_afru-aufnr.
IF sy-subrc <> 0.
DELETE it_afru[].
CONTINUE..
ENDIF.
ENDLOOP.
未完待续~~~
SAP内表查询速度优化实例-OPEN SQL的更多相关文章
- mysql索引原理及查询速度优化
一 介绍 为何要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语句 ...
- sap 内表
内表的目的在ABAP/4中,主要使用表格.表格是R/3系统中的关键数据结构.长期使用的数据存储在关系数据库表格中.关于如何读取和处理数据库表格的详细信息,参见读取并处理数据库表.除了数据库表格,还可以 ...
- mongodb多表查询(附带pymongo实例)
mongodb有$lookup可以做多表查询 举个例子 数据如下 db.orders.insert([ { , , }, { , , }, { } ]) db.inventory.insert([ { ...
- SAP内表转XML文件
今天有个兄弟问如何实现以XML的方式输出内表的内容,这个问题我以前好像没有写过.倒不是不会写,而是写的方法太多了,有极其简单的,也有很复杂的,而且网上资料也很多. 找到以前写的一个程序,稍微修改了一下 ...
- SAP内表类型及其数据读取效率评估
内表大概分3种: 1.标准表standard tables:如果不指定BINARY SEARCH附加选项,则默认为线性查找(linear search),既一条一条的查找. 2.排序表(sorted ...
- MySQL多表查询,Navicat使用,pymysql模块,sql注入问题
一.多表查询 #建表 create table dep( id int, name varchar(20) ); create table emp( id int primary key auto_i ...
- mysql经纬度查询并且计算2KM范围内附近用户的sql查询性能优化实例教程
之前很傻很天真地以为无非就是逐个计算距离,然后比较出来就行了,然后当碰到访问用户很多,而且数据库中经纬度信息很多的时候,计算量的迅速增长,能让服务器完全傻逼掉,还是老前辈的经验比我们丰富,给了我很大的 ...
- 记一次SqlServer大表查询语句优化和执行计划分析
数据库: sqlserver2008r2 表: device_data 数据量:2000w行左右 表结构 CREATE TABLE [dbo].[device_data]( [Id] [int] ID ...
- 记一次Hbase查询速度优化经历
项目背景: 在这次影像系统中,我们利用大数据平台做的是文件(图片.视频等)批次的增删改查,每个批次都包含多个文件,上传完成以后要添加文件索引(文件信息及批次信息),由于在Hbase存储的过程中,每个文 ...
随机推荐
- 76.Longest Consecutive Sequence(最长的连续序列)
Level: Hard 题目描述: Given an unsorted array of integers, find the length of the longest consecutive ...
- Go语言_流程控制语句:for、if、else、switch 和 defer
流程控制语句:for.if.else.switch 和 defer 学习如何使用条件.循环.分支和推迟语句来控制代码的流程. Go 作者组编写,Go-zh 小组翻译. https://go-zh.or ...
- asp.net ajax的使用
参考:https://www.cnblogs.com/acles/articles/2385648.html https://www.cnblogs.com/xujingyang/p/5560646. ...
- 【彩彩只能变身队(第七组)】Beta版本
本篇博客包括前期博文汇总.任务墙.团队管理细节与交流细节.代码管理.Beta阶段冲刺.团队总结.用户使用报告.Postmortem报告. 服务器网址:http://47.106.227.154/ 彩彩 ...
- 2018-8-10-win10-uwp-毛玻璃
title author date CreateTime categories win10 uwp 毛玻璃 lindexi 2018-08-10 19:16:50 +0800 2018-2-13 17 ...
- 记一次redis读取超时的排查过程(SADD惹的祸)
问题背景 在业务使用redis过程中,出现了read timeout 的异常. 问题排查 直接原因 运维查询redis慢查询日志,发现在异常时间节点,有redis慢查询日志,执行sadd 命令花费了1 ...
- nuxtJs - axios 的 IE 兼容性的问题
因为考虑SEO, 所以采用nuxt.js进行服务端渲染, 用熟了vue, nuxt无缝对接简直不要太爽 烦人的需求又来了, 要兼容IE ~~ 兼容处理 无非就是babel 将高级语法转成弱智IE看得懂 ...
- java基础复习(一)
一.常用的DOS命令 打开命令提示符窗口的方式: ① win + R --> 输入cmd --> 回车 ② 开始 --> 搜索程序和文件的框中输入 cmd --> 回车 ...
- B/S架构和C/S架构介绍
一.C/S架构 C/S架构及其背景 C/S架构是一种比较早的软件架构,主要应用于局域网内.在这之前经历了集中计算模式,随着计算机网络的进步与发展,尤其是可视化工具的应用,出现过两层C/S和三层C/S架 ...
- intellij IDEA启动springboot项目报无效的源发行版错误解决方法
从http://start.spring.io/ 上下载的springboot 模板项目,导入intellij 后,报如下错误,原因是intellij 默认使用的Java compiler 是1.8版 ...