SAP BPC 开发日记
1.获取维度模型的方法1
DATA:i_appset_id TYPE uj_appset_id,
i_appl_id TYPE uj_appl_id.
i_appset_id = 'SINOTRUK'.
i_appl_id = 'Consolidation'.
DATA: lo_owner_model TYPE REF TO cl_uja_application,"ownership 模型
lt_owner_dim TYPE uja_t_appl_dim. "ownership 模型的维度list
CREATE OBJECT lo_owner_model
EXPORTING
i_appset_id = i_appset_id
i_application_id = 'OWNERSHIP'.
lo_owner_model->get_appl_dim(
EXPORTING
i_appl_id = 'OWNERSHIP'
IMPORTING
et_appl_dim = lt_owner_dim ).
2获取维度模型方法2
cl_ujk_model=>get_dim_list(
EXPORTING
i_appset_id = i_appset_id
i_appl_id = 'Ownership'
i_with_measures = abap_false
IMPORTING
et_admin_dim_list = DATA(lt_dim_list)
).
3.设置查询条件
DATA: lt_sel TYPE uj0_t_sel. "输入模型的查询条件
"设置查询条件
DEFINE set_select.
APPEND INITIAL LINE TO &1 ASSIGNING <lfs_sel> .
<lfs_sel>-sign = &2.
<lfs_sel>-option = &3.
<lfs_sel>-dimension = &4.
<lfs_sel>-low = &5.
<lfs_sel>-high = &6.
END-OF-DEFINITION.
"维度 ACCOUNT
set_select lt_sel 'I' 'BT' 'ACCOUNT' '1521010000' '1521010002'.
set_select lt_sel 'I' 'BT' 'ACCOUNT' '1522010000' '1522010002'.
set_select lt_sel 'I' 'BT' 'ACCOUNT' '1523010000' '1523010002'.
set_select lt_sel 'I' 'BT' 'ACCOUNT' '1521020000' '1521020001'.
"维度 FLOW
set_select lt_sel 'I' 'BT' 'FLOW' 'F_4A1' 'F_4A5'.
set_select lt_sel 'I' 'BT' 'FLOW' 'F_4B1' 'F_4B5'.
"维度 FLOW1
set_select lt_sel 'I' 'EQ' 'FLOW1' 'F1_NONE' ''.
"维度 FLOW2
set_select lt_sel 'I' 'EQ' 'FLOW2' 'F2_NONE' ''.
"维度 FLOW4
set_select lt_sel 'I' 'EQ' 'FLOW4' 'F4_NONE' ''.
4.查询模型数据方法1
DATA:lt_sel TYPE uj0_t_sel, "输入模型的查询条件
DATA:i_appset_id TYPE uj_appset_id,
i_appl_id TYPE uj_appl_id.
i_appset_id = 'SINOTRUK'.
i_appl_id = 'Consolidation'.
TRY .
*执行查询 ----开始
DATA(lo_query) = cl_ujo_query_factory=>get_query_adapter(
i_appset_id = i_appset_id
i_appl_id = i_appl_id ).
CALL METHOD lo_conso_mgr->create_data_ref
EXPORTING
i_data_type = 'T'
it_dim_name = lt_conso_dim
if_tech_name = abap_false
if_signeddata = abap_true
IMPORTING
er_data = lr_data_4.
ASSIGN lr_data_4->* TO <lfs_data>.
lo_query->run_rsdri_query(
EXPORTING
it_dim_name = lt_conso_dim " BPC: Dimension List
it_range = lt_sel " BPC: Selection condition
if_check_security = abap_true " BPC: Generic indicator
IMPORTING
et_data = <lfs_data>
).
*执行查询 ----结束
CATCH cx_root INTO DATA(lr_exception).
ENDTRY.
5.查询模型数据方法2
DATA: lo_owner_mgr TYPE REF TO if_uja_application_manager,
lt_owner_list TYPE uja_t_dim_list,
lr_data1 TYPE REF TO data,
lt_axis1 TYPE ujo_t_query_dim,
ls_axis TYPE ujo_t_members.
FIELD-SYMBOLS:
<fs_table01> TYPE STANDARD TABLE,
*---读取OWNERSHIP(/CPMB/CYIY0HO)模型
TRY.
CALL METHOD cl_uja_bpc_admin_factory=>get_application_manager
EXPORTING
i_appset_id = i_appset_id
i_application_id = 'Ownership'
RECEIVING
ro_return = lo_owner_mgr.
CALL METHOD lo_owner_mgr->create_data_ref
EXPORTING
i_data_type = 'T'
it_dim_name = lt_owner_list
if_tech_name = abap_false
if_signeddata = abap_true
IMPORTING
er_data = lr_data1.
ASSIGN lr_data1->* TO <fs_table01>.
lo_owner_query = cl_ujo_query_factory=>get_query_adapter(
i_appset_id = i_appset_id
i_appl_id = 'Ownership' ).
lo_owner_query->run_axis_query_symm(
EXPORTING
it_axis = lt_axis1 " BPC: Dimension List
if_no_sign_conversion = abap_true
IMPORTING
et_data = <fs_table01>
).
CATCH cx_ujo_read cx_uj_static_check.
ENDTRY.
SAP BPC 开发日记的更多相关文章
- SAP BPC方案介绍
refer to http://sapper.blog.sohu.com/166039991.html SAP/BPC简介: 全面预算管理是联系公司战略目标与日常运营的重要纽带,它上到战略层面.下到执 ...
- 微信小程序开发日记——高仿知乎日报(中)
本人对知乎日报是情有独钟,看我的博客和github就知道了,写了几个不同技术类型的知乎日报APP要做微信小程序首先要对html,css,js有一定的基础,还有对微信小程序的API也要非常熟悉 我将该教 ...
- 微信小程序开发日记——高仿知乎日报(上)
本人对知乎日报是情有独钟,看我的博客和github就知道了,写了几个不同技术类型的知乎日报APP 要做微信小程序首先要对html,css,js有一定的基础,还有对微信小程序的API也要非常熟悉 我将该 ...
- 嵌入式Linux驱动开发日记
嵌入式Linux驱动开发日记 主机硬件环境 开发机:虚拟机Ubuntu12.04 内存: 1G 硬盘:80GB 目标板硬件环境 CPU: SP5V210 (开发板:QT210) SDRAM: 512M ...
- 【原创】shadowebdict开发日记:基于linux的简明英汉字典(四)
全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...
- 【原创】shadowebdict开发日记:基于linux的简明英汉字典(三)
全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...
- 【原创】shadowebdict开发日记:基于linux的简明英汉字典(二)
全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...
- 【原创】shadowebdict开发日记:基于linux的简明英汉字典(一)
全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...
- LayIM.AspNetCore Middleware 开发日记(一)闲言碎语
前言 前几天写博客的时候突然看见了历史上的今天.不禁感慨时光如梭,这系列博客后来被我标注了已经过时,但是还有很多小伙伴咨询我.既然过时就要更新,正好 .NET Core 也出来很久了,于是乎想到把La ...
随机推荐
- 8.Jenkins进阶之流水线pipeline基础使用实践(1)
目录一览: 0x01 基础实践 (1) Maven 构建之 Pipeline Script (2) Maven 构建之 Pipeline Script from SCM (3) Jenkins pi ...
- 安卓记账本开发学习day5之版本兼容问题
安卓5.0以上版本想要隐藏DatePicker头布局的写法比较复杂,需要一层一层隐藏 int headerId = getContext().getResources().getIdentifier( ...
- 2022.02.27 CF811E Vladik and Entertaining Flags(线段树+并查集)
2022.02.27 CF811E Vladik and Entertaining Flags(线段树+并查集) https://www.luogu.com.cn/problem/CF811E Ste ...
- for in 语法遍历对象
1. 语法格式 for (变量 in 对象) { console.log(变量) } 2. 代码实例 // 遍历对象 var obj = { name: 'pink老师', age: 18, se ...
- 手写一个bind
1 Function.prototype.bind1 = function(){ 2 // 将类数组转化成数组 3 let arr = Array.prototype.slice.call(argum ...
- C# iText 7 切分PDF,处理PDF页面大小
一.itext 我要使用itext做一个pdf的页面大小一致性处理,然后再根据数据切分出需要的pdf. iText的官网有关于它的介绍,https://itextpdf.com/ 然后在官网可以查找a ...
- 『现学现忘』Git基础 — 18、Git对象的总结
目录 1.Git操作最基本的流程 2.工作目录中文件的状态 3.Git效率说明 提示:前面三篇文章已经分别的对blob对象.tree对象.commit对象进行了详细的说明,这篇文章我们总结一下,Git ...
- cookie、sessionStorage、localStorage的区别?
数据存储位置 三者都是存储在游览器本地的 区别在于cookie是服务器端写入的,而sessionStorage.localStorage是由前端写入的 生命周期 cookie的生命周期是由服务器端写入 ...
- [笔记] prufer 序列
什么是 prufer 序列 是可以和 \(n\) 个有标号节点的无根树一一对应的长度为 \(n-2\) 的序列. 一般来说是用于和树相关的组合计数问题,但是可能会出现一些变形,所以除了要了解一些性质, ...
- windows下载安装JDK8
一 .下载链接 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 根据自己的电脑安 ...