一、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的更多相关文章

  1. mysql索引原理及查询速度优化

    一 介绍 为何要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语句 ...

  2. sap 内表

    内表的目的在ABAP/4中,主要使用表格.表格是R/3系统中的关键数据结构.长期使用的数据存储在关系数据库表格中.关于如何读取和处理数据库表格的详细信息,参见读取并处理数据库表.除了数据库表格,还可以 ...

  3. mongodb多表查询(附带pymongo实例)

    mongodb有$lookup可以做多表查询 举个例子 数据如下 db.orders.insert([ { , , }, { , , }, { } ]) db.inventory.insert([ { ...

  4. SAP内表转XML文件

    今天有个兄弟问如何实现以XML的方式输出内表的内容,这个问题我以前好像没有写过.倒不是不会写,而是写的方法太多了,有极其简单的,也有很复杂的,而且网上资料也很多. 找到以前写的一个程序,稍微修改了一下 ...

  5. SAP内表类型及其数据读取效率评估

    内表大概分3种: 1.标准表standard tables:如果不指定BINARY SEARCH附加选项,则默认为线性查找(linear search),既一条一条的查找. 2.排序表(sorted ...

  6. MySQL多表查询,Navicat使用,pymysql模块,sql注入问题

    一.多表查询 #建表 create table dep( id int, name varchar(20) ); create table emp( id int primary key auto_i ...

  7. mysql经纬度查询并且计算2KM范围内附近用户的sql查询性能优化实例教程

    之前很傻很天真地以为无非就是逐个计算距离,然后比较出来就行了,然后当碰到访问用户很多,而且数据库中经纬度信息很多的时候,计算量的迅速增长,能让服务器完全傻逼掉,还是老前辈的经验比我们丰富,给了我很大的 ...

  8. 记一次SqlServer大表查询语句优化和执行计划分析

    数据库: sqlserver2008r2 表: device_data 数据量:2000w行左右 表结构 CREATE TABLE [dbo].[device_data]( [Id] [int] ID ...

  9. 记一次Hbase查询速度优化经历

    项目背景: 在这次影像系统中,我们利用大数据平台做的是文件(图片.视频等)批次的增删改查,每个批次都包含多个文件,上传完成以后要添加文件索引(文件信息及批次信息),由于在Hbase存储的过程中,每个文 ...

随机推荐

  1. python学习第六天运算符总结大全

    python学习第六天运算符总结大全,玖乐网络(www.96net.com.cn)列出下面详细 1,算术运算符 + 加 - 减 *乘 / 除 % 求模 ** 乘方 // 取整除 - 返回商的整数部分 ...

  2. BUUCTF--新年快乐

    测试文件:https://buuoj.cn/files/bbf9f68a97fd551edec384914d4f3fbe/93c43c5c-3d4d-4d17-a9a1-4ffb65ebb2fb.zi ...

  3. Linux下svn回滚

    方法1: 用svn merge 1) 先 svn up,保证更新到最新的版本,如20: 2) 然后用 svn log ,查看历史修改,找出要恢复的版本,如10 .如果想要更详细的了解情况,可以使用sv ...

  4. 270-VC709E 增强版 基于FMC接口的Xilinx Vertex-7 FPGA V7 XC7VX690T PCIeX8 接口卡

    VC709E 增强版 基于FMC接口的Xilinx Vertex-7 FPGA V7 XC7VX690T PCIeX8 接口卡 一.板卡概述       本板卡基于Xilinx公司的FPGA XC7V ...

  5. Shell04--循环语句

    目录 Shell04---循环语句 1. 循环语句for基本概述 2. 循环语句for场景示例 3. 循环语句while基本概述 4. 循环语句while场景示例 5. 内置跳出循环语句指令 Shel ...

  6. HDU4089/Uva1498 Activation 概率DP(好题)

    题意:Tomato要在服务器上激活一个游戏,一开始服务器序列中有N个人,他排在第M位,每次服务器会对序列中第一位的玩家进行激活,有四种结果: 1.有p1的概率会激活失败,这时候序列的状态是不变的.2. ...

  7. Java的GC机制及算法

    GC的阶段  对每个对象而言,垃圾回收分为两个阶段:finalization和reclamation.  finalization: 指运行这个对象的finalize的方法. reclamation: ...

  8. maven多模块

    https://www.cnblogs.com/lichking2017/p/8996939.html

  9. javascaipt中数组元素删除方法delete和splice

    一.用delete 删除数组中元素(少用) 说明:delete: 只是被删除的元素变成了 undefined ,即数组长度不变 //定义数组 var array=["aa",&qu ...

  10. 关于vue开发的常见问题

    一.vue单页面回退丢失参数的问题 可能有些跟我一样的新手同学会遇到一个问题,就是比如我从商品详情跳转到购物车,没问题,但是,购物车页面中点击浏览器的回退按钮,返回到detail页面时,你的动态数据( ...