在上一篇随笔中,我们建立了部门和子部门的双提示,并将部门和子部门做了关联。那么,本篇随笔我们重点介绍利用建好的双提示进行传参。

在操作之前,我们来看一个报告和分析的具体需求:

[1] 两个有关联的提示:部门和子部门。

1.部门包括北京销售部、郑州销售部(此处为小的模拟例子,具体项目实施中可以根据相应字段选取);

2.子部门包括北京销售1部、北京销售2部、郑州销售1组、郑州销售2组;

3.当部门的值为北京销售部时,子部门的值列表范围为:北京销售1部、北京销售2部;郑州销售部同理。

(已满足,并且:“部门”对应表示变量“PV_A”;“子部门”对应表示变量“PV_B”,详情查看随笔“Oracle Sales Cloud:报告和分析(BIEE)小细节1”)

[2] 新建商机明细报表,具体展示列包括:商机ID、名称、销售阶段、责任人、成功率、金额、利润、利润率、资源组织名称(部门)。

[3] 对于提示传参的要求。

1.当部门的值为北京销售部时,报表展示资源组织名称为整个北京销售部的数据(包括北京销售1部和北京销售2部);

2.当子部门的值为北京销售1部时,报表展示资源组织名称为北京销售1部的数据;当子部门的值为北京销售2部时,报表展示资源组织名称为北京销售2部的数据。

3.对于郑州销售部的情况同上。

现在,我们开始在BI中做满足这个需求的分析和仪表盘:

     (1)第1步:创建“CUX_商机明细报表”,选取对应数据展示列,如图1。

              注意:“资源组织名称”列对应的是子部门数据,因为资源对应的是各个销售人员,所在组织是相应的销售部门。

      图1:新建商机明细报表

    (2)第2步:添加过滤器,将过滤器转化为SQL。

      图2:添加过滤器

    (3)第3步:修改过滤器的SQL,如图3。

             注意:此处取值为SQL结果,该处用到的查询方法为:union连接各个Select结果

               那么此处的SQL便是(此处取得字段为“资源所在组织”):

1.部门层次的结果限定

"Employee"."Resource Primary Organization Name" in (
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                  WHERE '@{PV_A}{}'is null
                     AND "Employee"."Resource Primary Organization Name" in ('北京销售1部','北京销售2部','郑州销售1组','郑州销售2组')
               union
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"
                  WHERE '@{PV_A}{}'='北京销售部'
                     AND "Employee"."Resource Primary Organization Name" in ('北京销售1部','北京销售2部')
               union
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                  WHERE '@{PV_A}{}'='郑州销售部'
                     AND "Employee"."Resource Primary Organization Name" in ('郑州销售1组','郑州销售2组')
              )

              2.子部门层次的结果限定,和部门之间用“AND”连接

"Employee"."Resource Primary Organization Name" in (
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                  WHERE '@{PV_B}{}' is null
                     AND "Employee"."Resource Primary Organization Name" in ('北京销售1部','北京销售2部','郑州销售1组','郑州销售2组')
               union
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                 WHERE '@{PV_B}{}'= '北京销售1部'
                     AND "Employee"."Resource Primary Organization Name" = '北京销售1部'
               union
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                  WHERE '@{PV_B}{}'= '北京销售2部'
                     AND "Employee"."Resource Primary Organization Name" = '北京销售2部'
               union
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                  WHERE '@{PV_B}{}'= '郑州销售1组'
                     AND "Employee"."Resource Primary Organization Name" = '郑州销售1组'
               union
               SELECT DISTINCT "Resource Primary Organization Name" FROM "Sales - CRM Pipeline"  
                  WHERE '@{PV_B}{}'= '郑州销售2组'
                     AND "Employee"."Resource Primary Organization Name" = '郑州销售2组'
              )

图3:修改过滤器

  (4)第4步:将提示和明细报表放到同一仪表盘下部署即可。

      图4:新建仪表盘

总结:报告和分析(BI开发)小细节2——利用变量和过滤器进行传参(例如,根据提示展示不用部门的数据),主要介绍了利用表示变量和过滤器进行传参,进而让报表可以根据不同提示展示相对应的数据。同样需要注意:利用这个方法后,对于实际项目而言,一旦企业的组织架构做了调整,过滤器和提示一样也要进行对应修改。

谢谢,欢迎大家随时指正和交流!

Oracle Sales Cloud:报告和分析(BIEE)小细节2——利用变量和过滤器传参(例如,根据提示展示不同部门的数据)的更多相关文章

  1. Oracle Sales Cloud:报告和分析(BIEE)小细节1——创建双提示并建立关联(例如,部门和子部门提示)

    Oracle Sales Cloud(Oracle 销售云)是一套基于Oracle云端的客户商机管理系统,通过提供丰富的功能来帮助提高销售效率,更好地去了解客户,发现和追踪商机,为最终的销售成交 (d ...

  2. Oracle Sales Cloud:管理沙盒(定制化)小细节1——利用公式创建字段并显示在前端页面

    Oracle Sales Cloud(Oracle 销售云)是一套基于Oracle云端的CRM管理系统.由于 Oracle 销售云是基于 Oracle 云环境的,它与传统的管理系统相比,显著特点之一便 ...

  3. Oracle Sales Cloud:管理沙盒(定制化)小细节2——使用对象触发器更新数字字段

    在上一篇 "管理沙盒(定制化)小细节1" 的随笔中,我们使用公式法在 "业务机会" 对象(单头)上建立了 "利润合计" 字段,并将它等于 & ...

  4. arm汇编进入C函数分析,C函数压栈,出栈,传参,返回值

    环境及代码介绍 环境和源码 由于有时候要透彻的理解C里面的一些细节问题,所有有必要看看汇编,首先这一切的开始就是从汇编代码进入C的main函数过程.这里不使用编译器自动生成的这部分汇编代码,因为编译器 ...

  5. 【ORACLE】awr报告问题分析

    本文转自:http://www.linuxidc.com/Linux/2015-10/123959.htm 感谢分享 1.问题说明 运维人员都有"节日休假恐怖症",越到节日.休假和 ...

  6. 微信小程序和微信小程序之间的跳转和传参示例代码附讲解

    一:微信小程序跳转 使用限制 需要用户触发跳转 从 2.3.0 版本开始,若用户未点击小程序页面任意位置,则开发者将无法调用此接口自动跳转至其他小程序. 需要用户确认跳转 从 2.3.0 版本开始,在 ...

  7. JS分析URL字符串,取得参数名,AJAX传参请求代码示例

    //当前页面URL中参数分析函数,正则校验 function getQueryString(name) { var reg = new RegExp("(^|&)" + n ...

  8. 微信小程序——动态渲染页面、路径传参

      1.动态渲染页面.改变css.样式必须setData渲染过去   this.setData({ userInfo: app.globalData.userInfo, token: app.glob ...

  9. 微信小程序 子组件给父组件传参

    子组件给父组件传参只需这4步: 子组件的两步: 1.子组件绑定函数 addInfo <button type="primary" bindtap="addInfo& ...

随机推荐

  1. Prometheus 系统监控方案 一

    最近一直在折腾时序类型的数据库,经过一段时间项目应用,觉得十分不错.而Prometheus又是刚刚推出不久的开源方案,中文资料较少,所以打算写一系列应用的实践过程分享一下. Prometheus 是什 ...

  2. 基于AngularJs的上传控件-angular-file-upload

    今天跟大家分享的是一个依赖于angular的上传控件. 前段时间做项目遇到一个需求是上传文件,大概需要实现的样式是这样子的,见下图: 需要同时上传两个文件.并且规定文件格式和文件大小.因为前端框架使用 ...

  3. C#执行异步操作的几种方式比较和总结

    C#执行异步操作的几种方式比较和总结 0x00 引言 之前写程序的时候在遇到一些比较花时间的操作例如HTTP请求时,总是会new一个Thread处理.对XxxxxAsync()之类的方法也没去了解过, ...

  4. Lesson 16 A polite request

    Text If you park your car in the wrong place, a traffic policeman will soon find it. You will be ver ...

  5. 在 Ubuntu 14.10 中借用 Windows 的字体

    在前一篇随笔中,我详细讨论了字体的分类及用途,也以 Fedora 20 为例,展示了字体配置的思路和方法.我在配置 Fedora 20 系统字体的时候,采用的是一种釜底抽薪的方法,完全抛开了系统原有的 ...

  6. (原创) alljoyn物联网实验之手机局域网控制设备

    AllJoyn开源物联网协议框架,官方描述是一个能够使连接设备之间进行互操作的通用软件框架和系统服务核心集,也是一个跨制造商来创建动态近端网络的软件应用.高通已经将该项目捐赠给了一个名为“AllSee ...

  7. Spring集成MyBatis

    本文原创,原文地址为http://www.cnblogs.com/fengzheng/p/5045105.html 如果觉得Hibernate不够灵活,可以尝试用Mybatis.相比于Hibernat ...

  8. 跟我一起hadoop(1)-hadoop2.6安装与使用

    伪分布式 hadoop的三种安装方式: Local (Standalone) Mode Pseudo-Distributed Mode Fully-Distributed Mode 安装之前需要 $ ...

  9. [译]ZOOKEEPER RECIPES-Barriers

    Barrier 在分布式系统中常使用Barrier来阻塞进程,当满足一定条件后再恢复进行后续操作.Barrier在Zookeeper中可以通过设计一个Barrier节点来实现.Barrier 节点存在 ...

  10. Android开发学习之路-Git的极简教程?

    Git是一个代码版本管理工具,也就是允许我们的一个项目拥有多个版本,这样我们可以随心所欲的修改我们的代码,如果出现问题,可以回退到某一个提交点.如果你还在用一堆堆注释来更新你的代码,那么可以尝试一下G ...