博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SAP Study Notes: BW Queriy-Variables(变量)
阅读量:5896 次
发布时间:2019-06-19

本文共 2523 字,大约阅读时间需要 8 分钟。

About Variable:

1.Variable 是和InfoObject绑定的,可用于任何含有该IO的query中。
2.Variable有以下几种类型:
Characteristic:用于限制Char。 
Text:用于在报表动态显示文本。 
Hierarchy:用于限制Hierarchy。 
Hieararchy Node:用于限制Hierarchy Node。 
Formula: 可以在公式中使用变量,让用户输入一个数,读取某个Char.的属性(例如Prduct的price属性)等来用于计算。 
Offset的应用:设置偏移量
SAP BI Content内置了很多标准变量。当其无法满足需求时,有时仅仅需要设置下偏移量就可以满足需求了。
例如系统已经有了当前月份的变量,通过偏移就可以获得上N个月和下N个月的变量,无需增强。
 
定义Customer Exit Variables(BW 3.x ,BI7 类似)
客户出口变量可以通过程序来处理变量逻辑。定义过程如下:
1.在query designer中,右键单击要建立变量的characteristic,选择New variable.
2.设置为customer exit类型
3.进入CMOD,修改:Enhancement   Exp  RSR00001 BI: Enhancements for Global Variables in Reporting-->Function exit    EXIT_SAPLRRS0_001-->INCLUDE ZXRSRU01 。该Function Module 将在query运行时被调用多次。
3-1:调用前,系统将其他变量的当前值保存在内表 I_T_VAR_RANGE中。The table type is RRS0_T_VAR_RANGE, and row type RRS0_S_VAR_RANGE references structure RRRANGEEXIT.This structure has the following fields: 
Field                                     Description
 
VNAM                                   Variable name
 
IOBJNM                                 InfoObject name
 
SIGN                                      (I)ncluding [ ] or (E)xcluding ] [
 
OPT                                      Operators: EQ =, BT [ ], LE <=, LT <, GE >=, GT >, CP, and so on
 
LOW                                      Characteristic value
 
HIGH                                      Characteristic value of upper limit for intervals or node InfoObject for hierarchy nodes
 3-2:每次调用时,系统会传递参数值给Function Module。其中,比较重要的参数如下:

I_STEP 标识了该调用发生的时机:

 I_STEP = 1: Call is made directly before variable entry.

I_STEP = 2: Call is made directly after variable entry. This step is only executed if the same variable is not input-ready and could not be filled for I_STEP = 1.
I_STEP = 3: In this call, you can check the values of the variables. When an exception (RAISE) is triggered, the variable screen appears again. I_STEP = 2 is then also called again.
 I_STEP = 0: The enhancement is not called from the variable screen. The call can originate from the authorization check or from the monitor.
I_VNAM标识了当前要处理的变量。

3-3:完成变量的处理之后,应将变量的值写入E_T_RANGE。

Sample Code:

DATA: L_S_RANGE TYPE RSR_S_RANGESID.
DATA: L_S_VAR_RANGE TYPE RRRANGEEXIT. 
CASE I_VNAM.  
     WHEN 'CUMMONTH'.
        IF I_STEP = 2. "after the popup 
            READ TABLE I_T_VAR_RANGE INTO L_S_VAR_RANGE WITH KEY VNAM = 'MONTH'.
            IF SY-SUBRC = 0.
                    CLEAR L_S_RANGE.
                    L_S_RANGE-LOW = LOC_VAR_RANGE-LOW(4)."low value, for example, 200601
                    L_S_RANGE-LOW+4(2) = '01'.
                    L_S_RANGE-HIGH = LOC_VAR_RANGE-LOW. "high value = input
                    L_S_RANGE-SIGN = 'I'.
                    L_S_RANGE-OPT = 'BT'.
                   APPEND L_S_RANGE TO E_T_RANGE.
                ENDIF.
        ENDIF.
ENDCASE.

查看SAP Exit变量 

SAP Exit变量为我们编写customer exit变量提供了很好的参考。
1. SE16 查看表 RSZGLOBV 可以得到系统全部变量的列表,选择process type=SAP Exit,即可获得所有的SAP Exit变量列表
2. SE37 查看 RREX_VARIABLE_EXIT 或RSVAREXIT_ * 可以找到SAP Exit变量的代码

转载地址:http://kdxsx.baihongyu.com/

你可能感兴趣的文章
Android:LayoutInflater载入没有载入或想动态载入的layout
查看>>
A. Sorting Railway Cars
查看>>
二叉树——JAVA实现
查看>>
BZOJ2761:[JLOI2011]不重复数字(map)
查看>>
mongodb学习(六)索引
查看>>
asp.net 服务器控件的 ID,ClientID,UniqueID 的区别
查看>>
Flexbox属性可视化指南
查看>>
软件测试自动化…python学习到什么程度?代码好不好学!
查看>>
window.location.origin兼容问题
查看>>
从《硅谷传奇》看微软和苹果
查看>>
windows8 开发获得系统 app相关信息代码 c#版本
查看>>
【Android】7.1 布局控件常用的公共属性
查看>>
JAVASCRIPT变量的作用域
查看>>
springAop
查看>>
数字逻辑 第一章、编码 1.2 编 码
查看>>
如何搭建Nuget服务器
查看>>
图片自适应高度的问题
查看>>
CSS 设置table下tbody滚动条
查看>>
13-1 jQuery操作cookie
查看>>
2017-2018 20172309 《程序设计与数据结构(下)》第七章学习总结
查看>>