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 开发日记的更多相关文章

  1. SAP BPC方案介绍

    refer to http://sapper.blog.sohu.com/166039991.html SAP/BPC简介: 全面预算管理是联系公司战略目标与日常运营的重要纽带,它上到战略层面.下到执 ...

  2. 微信小程序开发日记——高仿知乎日报(中)

    本人对知乎日报是情有独钟,看我的博客和github就知道了,写了几个不同技术类型的知乎日报APP要做微信小程序首先要对html,css,js有一定的基础,还有对微信小程序的API也要非常熟悉 我将该教 ...

  3. 微信小程序开发日记——高仿知乎日报(上)

    本人对知乎日报是情有独钟,看我的博客和github就知道了,写了几个不同技术类型的知乎日报APP 要做微信小程序首先要对html,css,js有一定的基础,还有对微信小程序的API也要非常熟悉 我将该 ...

  4. 嵌入式Linux驱动开发日记

    嵌入式Linux驱动开发日记 主机硬件环境 开发机:虚拟机Ubuntu12.04 内存: 1G 硬盘:80GB 目标板硬件环境 CPU: SP5V210 (开发板:QT210) SDRAM: 512M ...

  5. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(四)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  6. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(三)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  7. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(二)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  8. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(一)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  9. LayIM.AspNetCore Middleware 开发日记(一)闲言碎语

    前言 前几天写博客的时候突然看见了历史上的今天.不禁感慨时光如梭,这系列博客后来被我标注了已经过时,但是还有很多小伙伴咨询我.既然过时就要更新,正好 .NET Core 也出来很久了,于是乎想到把La ...

随机推荐

  1. C. Tourist Problem 2021.3.29 晚vj拉题 cf 1600 纯数学题

    拉题链接  https://vjudge.net/contest/430219#overview 原题链接  https://codeforces.com/problemset/problem/340 ...

  2. 一键智能Mock,你值得拥有

    ​ 大家好呀,我是一名苦逼的前端开发工程师,为啥苦逼呢,这不,项目下周就要上线了,但是后端还没给我接口,没有接口我就无法调试,工作停滞不前,我也只能坐着干着急. 我报告给了我的老板山哥: 老板,这后端 ...

  3. 2021.08.01 P4359 伪光滑数(二叉堆)

    2021.08.01 P4359 伪光滑数(二叉堆) [P4359 CQOI2016]伪光滑数 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 若一个大于 11 的整数 MM ...

  4. 倒计时第3天!Google Summer of Code报名即将截止!(Casbin社区还有空缺名额)

    Google Summer of Code 介绍 Google Summer of Code ( GSoC ,即 Google 编程之夏)是 Google (谷歌)组织并提供经费,面对全球在读学生的在 ...

  5. 如何使用 pyqt 实现 Groove 音乐播放器

    前言 Win10 自带了一款很好用的音乐播放器 -- Groove 音乐,但是只能支持本地音乐的播放.2020年3月底到4月底,自己一直在学习 PyQt5,然后从 2020年5月开始,着手使用 PyQ ...

  6. Java 线程池四种拒绝策略

    jdk1.5版本新增了 JUC 并发包,其中一个包含线程池. 四种拒绝策略: 拒绝策略类型 说明 1 ThreadPoolExecutor.AbortPolicy 默认拒绝策略,拒绝任务并抛出任务 2 ...

  7. 用 Docker 快速搭建 Kafka 集群

    开源Linux 一个执着于技术的公众号 版本 •JDK 14•Zookeeper•Kafka 安装 Zookeeper 和 Kafka Kafka 依赖 Zookeeper,所以我们需要在安装 Kaf ...

  8. 公司官网建站笔记(一):腾讯云服务器装CentOS8.2系统、重置密码、远程ssh登陆、sftp传递文件以及新建开发者账户

    前言   本篇使用的是腾讯云服务器,讲解了部署安装服务器CentOS8.2系统,重置密码,添加用户,远程登陆,远程传递文件等基本流程.   前提条件   购买了腾讯云服务器,如下图:     云服务器 ...

  9. 想学会SOLID原则,看这一篇文章就够了!

    背景 在我们日常工作中,代码写着写着就出现下列的一些臭味.但是还好我们有SOLID这把'尺子', 可以拿着它不断去衡量我们写的代码,除去代码臭味.这就是我们要学习SOLID原则的原因所在. 设计的臭味 ...

  10. JZ009乘积小于k的子数组

    title: 乘积小于k的子数组 题目描述 题目链接:乘积小于k的子数组.剑指offer009 解题思路 注意: 一开始的乘积k值就是小的,随着右边窗口移动才会不断增大 怎么样的条件才能更新左窗口:当 ...