ABAP Range Table:RANGES的使用

目录

  • Range Table
    • RANGE
    • RANGES
  • RANGE的四个参数
    • SIGN
    • OPTION
    • LOW
    • HIGH
    • 示例程序

Range Table

1、Range Table 概述
RANGE TABLE为 SAP R/3系统标准内表的一种,结构与 Selection Table 一致,
由 SIGN, OPTION, LOW 和 HIGH字段组成;

可以通过 TYPE RANGE OF 语句或 RANGES 关键字定义 Range Table。
Range Table 常用于Open SQL语句中的条件筛选,可以优化取数效率与程序性能。
2.定义Range Table
可以通过两种方式定义:

  1. TYPE RANGE OF…
    DATA rtab {TYPE RANGE OF type}|{LIKE RANGE OF dobj}
    [INITIAL SIZE n]
    [WITH HEADER LINE]
    [VALUE IS INITIAL]
    [READ-ONLY].

  2. RANGES
    语法:
    RANGES rtab FOR dobj [OCCURS n].

在程序上右击,点击“New ABAP Program“:
在这里插入图片描述
输入程序名和描述,点击下一步:
在这里插入图片描述

选择一个请求号,点击完成:
在这里插入图片描述

RANGE

使用... TYPE RANGE OF ...来定义一个range

DATA gt_marc TYPE TABLE OF marc.
DATA: gr_werks TYPE RANGE OF werks_d,"WERKS_D是一个数据元素gw_werks LIKE LINE OF gr_werks.
"这里需要注意,For后面字段必须为参考表的字段,不能使用 Data Element 来定义,否则系统会报出错误。
"宏定义
DEFINE set_range_werks.gw_werks-sign = 'I'.gw_werks-option = 'EQ'.gw_werks-low = &1.APPEND gw_werks TO gr_werks.
END-OF-DEFINITION.SELECT * FROM marc INTO CORRESPONDING FIELDS OF TABLE gt_marc
WHERE werks IN gr_werksAND ekgrp IN gr_ekgrpAND beskz IN gr_beskz.

在这里插入图片描述

RANGES

使用RANGES来定义一个RANGE TABLE

*-------------------------------------------
* 通过 RANGES 定义
*-------------------------------------------TABLES:marc.
RANGES: gr_ekgrp FOR marc-ekgrp.
DATA gw_ekgrp LIKE LINE OF gr_ekgrp.
RANGES: gr_bwtty FOR marc-bwtty.
RANGES: gr_beskz FOR marc-beskz.

有时候我们取值不是一个定值,而是一个范围,这个时候就需要我们用ranges去定义:
在这里插入图片描述

运行结果:
在这里插入图片描述

RANGE的四个参数

SIGN

• SIGN 可以取以下两种值:INCLUED 和 EXCLUDE
sign = ‘I’ ‘I’ 表示包含(INCLUDE):LOW 、HIGH的值
sign = ‘E’ ‘E’ 表示排除(EXCLUDE):LOW、HIGH的值

OPTION

• OPTION 运算符可以取以下值:
‘EQ’ , ‘NE’ "等于,不等于 Equal ,Not Equal
‘GT’ , ‘LT’ "大于,小于 Greater Than ,Less Than
‘GE’ , ‘LE’ "大于等于,小于等于 Greater Than or Equal ,Less Than or Equal
‘CP’ , ‘NP’ “参考判断格式,如"ABC*”,NP排除参考格式
‘BT’ , ‘NB’ "位于,不位于,功能与 Between 和 Not Between 一样。

LOW

• LOW 是指当前值,或区间最小值(操作符是范围的话)
LOW:LOW的数据类型与数据库表的列类型相同,该表与选择标准相连接。
如果 Option 运算符不为 ‘BT’ 或 ‘NB’,LOW的内容定义单值选择,它与OPTION中的运算符相结合,为数据库选择指定了条件。
如果 Option 运算符为 ‘BT’ 或 ‘NB’,并且 HIGH 不为空, LOW和HIGH中的内容为间隔选择指定上界和下界,与OPTION中的运算符相结合,该间隔为数据库选择指定了条件。

HIGH

• HIGH 是指区间最大值
如果 Option 运算符为 ‘BT’ 或 ‘NB’,HIGH 的值才会生效,运算符不是Between 和 Not Between 时,high有值也不会参与计算

s_KVGR1-sign = 'I'.
s_KVGR1-option = 'EQ'.   "包括 等于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].   "输出结果003s_KVGR1-sign = 'E'.
s_KVGR1-option = 'EQ'.   "排除 等于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果除003外所有s_KVGR1-sign = 'I'.
s_KVGR1-option = 'NE'.   "包括 不等于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果除003外所有s_KVGR1-sign = 'E'.
s_KVGR1-option = 'NE'.  "排除 不等于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].   "输出结果003s_KVGR1-sign = 'E'.
s_KVGR1-option = 'GT'.  "排除 大于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果001003  2条记录(应该是3条,数据表没有002这条记录)s_KVGR1-sign = 'E'.
s_KVGR1-option = 'LT'.   "排除 小于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].   "输出结果003004……  等21条记录s_KVGR1-sign = 'E'.
s_KVGR1-option = 'GE'.  "排除 大于等于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果001  1条记录(应该是2条,数据表没有002这条记录)s_KVGR1-sign = 'E'.
s_KVGR1-option = 'LE'.   "排除 小于等于 003 的记录
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].   "输出结果004005……  等20条记录"这两个测试不出来,每次出来都是全部或者空,先不管它们
"'CP' , 'NP'   "参考判断格式,如"ABC*",NP排除参考格式s_KVGR1-sign = 'I'.
s_KVGR1-option = 'BT'.   "包含 位于 003007 的记录,闭区间
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果003004……007  5条记录s_KVGR1-sign = 'E'.
s_KVGR1-option = 'BT'.  "排除 位于 003007 的记录,闭区间
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].   "输出结果001008009……   等17条记录s_KVGR1-sign = 'I'.
s_KVGR1-option = 'NB'.   "包含 不位于 003007 的记录,闭区间
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果001008009……   等17条记录s_KVGR1-sign = 'E'.
s_KVGR1-option = 'NB'.  "排除 不位于 003007 的记录,闭区间
s_KVGR1-low = '003'.
s_KVGR1-high = '007'.
APPEND s_KVGR1 TO s_KVGR1[].  "输出结果003004……007  5条记录SELECT * FROM tvv1t INTO CORRESPONDING FIELDS OF TABLEit_tvv1t WHERE spras = '1' AND kvgr1 IN s_KVGR1. 

示例程序

TABLES:marc.
RANGES: gr_ekgrp FOR marc-ekgrp.
DATA gw_ekgrp LIKE LINE OF gr_ekgrp.
RANGES: gr_bwtty FOR marc-bwtty.
RANGES: gr_beskz FOR marc-beskz.gr_beskz-sign = 'E'. "在区间外
gr_beskz-option = 'BT'. "在什么之间
gr_beskz-low = 'F'.
gr_beskz-high = 'X'.
APPEND gr_beskz TO gr_beskz[].  "将数据插入gr_beskz[] SELECT * FROM marc INTO CORRESPONDING FIELDS OF TABLE gt_marc
WHERE werks IN gr_werksAND ekgrp IN gr_ekgrpAND beskz IN gr_beskz.

在这里插入图片描述
现在就是在F-X区间的范围之外的,排除 从F 到 X区间的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/664170.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

10. BI - 决策树的使用及可视化

本文为 「茶桁的 AI 秘籍 - BI 篇 第 10 篇」 文章目录 可视化探索决策树原理决策树算法决策树可视化泰坦尼克海难数据 Hi,你好。我是茶桁。 上一节课,咱们了解了图形的具体绘制方法,接下来咱们还要看看除了图形绘制之外,还有哪些…

机器学习入门-----sklearn

机器学习基础了解 概念 机器学习是人工智能的一个实现途径 深度学习是机器学习的一个方法发展而来 定义:从数据中自动分析获得模型,并利用模型对特征数据【数据集:特征值+目标值构成】进行预测 算法 数据集的目标值是类别的话叫做分类问题;目标值是连续的数值的话叫做回…

yum命令下载出现Failed to synchronize cache for repo ‘AppStream‘, ignoring this repo.

修改下面的配置文件 问题: cd /etc/yum.repos.d 修改下面四个文件 vim CentOS-Base.repo vim CentOS-AppStream.repo vim CentOS-Extras.repo vim CentOS-PowerTools.repo测试yum是否正常 yum -y install wget

MATLAB知识点:矩阵的拼接和重复

​讲解视频:可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇(数学建模清风主讲,适合零基础同学观看)_哔哩哔哩_bilibili 节选自第3章 3.3.4 矩阵的拼接和重复 有时候我们需要对多个矩…

word调整论文格式的记录

页眉的分章显示内容 效果: 步骤: 确保“显示/隐藏的标记”符号打开点亮 前提是章节前面有“分节符(下一页)”,没有则添加,在菜单栏“布局”——》“下一页” 添加页眉,双击页眉,选…

Cocos XR的WebBox实现流程

1. 正常3D场景下的webview 1.1 组件角色 Cocos Creator正常3D场景下只有在UI组件才支持webview,即作为下图中的UI Nodes(Canvas Node)的子节点,和3D组件是隔离开的,不能显示在3D空间中,UI Nodes(Canvas Node)是一个平面内的矩形…

jsp 样衣申请与归还管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 样衣申请与归还管理系统是一套完善的java web信息管理系统,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境 为TOMCAT7.0,Myeclipse8.5开发,数据库为My…

链表——C语言——day17

链表 链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构。在用数组存放数据时,必须事先定义固定的长度(即元素个数)。链表则没有这种缺点,它根据需要开辟内存单元。 链表有一个“头指针“变量,图中…

【力扣白嫖日记】SQL

前言 练习sql语句,所有题目来自于力扣(https://leetcode.cn/problemset/database/)的免费数据库练习题。 今日题目: 1407.排名靠前的旅行者 表:Users 列名类型idintnamevarchar id 是该表中具有唯一值的列。name …

whale-quant 学习 part7:量化回测

量化回测 计算策略评估指标聚宽平台量化回测实践策略实现 参考 计算策略评估指标 使用数据为:贵州茅台(600519.SH)、工商银行(601398.SH)、中国平安(601318.SH),策略基准是沪深300指…

正则表达式与文本处理工具

目录 引言 一、正则表达式基础 (一)字符匹配 1.基本字符 2.特殊字符 3.量词 4.边界匹配 (二)进阶用法 1.组与引用 2.选择 二、命令之-----grep (一)基础用法 (二)高级用…

MySQL中去除重复(十一)

MySQL中去除重复(十一) 一、相同的行 我们要去除相同行要使用DISTINCT关键字 SELECT DISTINCT 列名 FROM 表名; distinct 是针对查询的结果集合进行去重而不是针对某一行或者某一列。 二、查询中的行选择 用 WHERE 子句限制从查询返回的行。一个 WHERE 子句包含一个 必须满…

智能分析网关V4+EasyCVR视频融合平台——高速公路交通情况的实时监控和分析一体化方案

随着2024年春运帷幕的拉开,不少人的返乡之旅也即将开启,从这几日的新闻来看,高速上一路飘红。伴随恶劣天气,加上激增的车流,极易导致高速瘫痪,无法正常使用。为解决此问题,助力高速高效运营&…

一些你可能用到的函数和头文件

对于排序想必大家应该挺熟悉的&#xff0c;如果要是给一连串打乱的整数让你由小到大排序&#xff0c;常见的方法有冒泡排序法和选择排序法等&#xff0c;今天我就给大家介绍一个十分好用的方法&#xff0c;就是使用 sort 函数来进行快排。 sort 函数是位于头文件 #include <…

R语言分析任务:

有需要实验报告的可CSDN 主页个人私信 《大数据统计分析软件&#xff08;R语言&#xff09;》 实 验 报 告 指导教师&#xff1a; 专 业&#xff1a; 班 级&#xff1a; 姓 名&#xff1a; 学 …

Three.js 纹理贴图 - 环境贴图 - 纹理贴图 - 透明贴图 - 高光贴图

文章目录 Three.js 纹理贴图纹理贴图 map属性纹理贴图的映射方式 texture.Mapping纹理贴图的色彩空间 texture.colorSpace中途更新纹理的色彩空间 texture.needsUpdate 纹理加载器 THREE.TextureLoader监听单个材质监听多个材质 - LoadingManager类 1. 颜色贴图与材质的颜色2.渲…

Linux——存储管理

文章目录 基本分区磁盘简介磁盘分类linux的磁盘命名磁盘的分区方式 管理磁盘虚拟机添加硬盘查看磁盘信息磁盘分区流程创建分区创建文件系统挂载mount查看挂载信息 剩余空间继续分区MBR如何划分更多的分区为什么只能有4个主分区扩展分区的引入 逻辑卷LVM是什么特点术语创建LVMVG…

数据图表方案,企业视频生产数据可视化

在信息爆炸的时代&#xff0c;如何将复杂的数据转化为直观、生动的视觉信息&#xff0c;是企业在数字化转型中面临的挑战。美摄科技凭借其独特的数据图表方案&#xff0c;为企业在数据可视化领域打开了一扇全新的大门。 一、数据图表方案的优势 1、高效便捷&#xff1a;利用数…

vscode实时预览markdown效果

安装插件 Markdown Preview Enhanced 上面是搜索框 启动预览 右键->Open Preview On the Side 效果如下&#xff1a; 目录功能 目录功能还是使用gitee吧 push后使用gitee&#xff0c;gitee上markdown支持侧边生成目录

Android矩阵Matrix裁切setRectToRect拉伸Bitmap替代Bitmap.createScaledBitmap缩放,Kotlin

Android矩阵Matrix裁切setRectToRect拉伸Bitmap替代Bitmap.createScaledBitmap缩放&#xff0c;Kotlin class MyImageView : AppCompatImageView {private var mSrcBmp: Bitmap? nullprivate var testIV: ImageView? nullconstructor(ctx: Context, attrs: AttributeSet) :…