cognos report同比环比以及默认为当前月分析
现在的需求是按月份分析不同时期的余额数据,.(报表工具:cognos report;建模工具:FM)
-------------------------------------------------------------------------------------------------------------------------------
实现效果:用户第一次点击报表,当前月余额,上一个月余额,去年这个月的余额。
技术点:同比环比,值提示设置默认值
step1:创建提示页面,给值提示设置默认值,自动提交表单,界面如下
html项目都是为了写JS
前面html处代码为 <div style="display:none">,这里不过多描述,就是为了不显示提示页面。
后面html处代码为
<script>
function getcurrentmonth()
{
var dtToday = new Date();
var nowyear=dtToday.getUTCFullYear();
var nowmonth1=dtToday.getMonth()+1;
var nowquarter="";
var nowmonth="";
if(nowmonth1>0&&nowmonth1<4)
{
nowquarter="Q1]";
}
if(nowmonth1>3&&nowmonth1<7)
{
nowquarter="Q2]";
}
if(nowmonth1>6&&nowmonth1<10)
{
nowquarter="Q3]";
}
if(nowmonth1>9&&nowmonth1<13)
{
nowquarter="Q4]";
}
if(nowmonth1>0&&nowmonth1<10)
{
nowmonth=["0",nowmonth1].join("");
}
else
{
nowmonth=nowmonth1;
}
var str1="[Presentation Layer].[报表月份].[报表月份].[月]->[all].[";
var str2= [nowyear,"]"].join("");
var str11= [str1,str2].join("");
var str4= ["[",nowyear].join("");
var str22= [str4,nowquarter].join("");
var str5= ["[",nowyear].join("");
var str6= [nowmonth,"]"].join("");
var str33=[str5,str6].join("");
str7= [str11,"."].join("");
str8= [str7,str22].join("");
str9= [str8,"."].join("");
str10= [str9,str33].join("");
return str10;
}
function init()
{
var form=getFormWarpRequest();
var mylist1= form._oLstChoicesdefaultmonth;//粗体部分为提示页面中值提示的名称,而不是参数名称。
for(var i=0;i<mylist1.length;i++)
{
if(mylist1[i].value==getcurrentmonth())
{
mylist1[i].selected="true";
}
}
promptButtonFinish();
}
</script>
<body onload=" init()">
</body>
</div>
解释:在getcurrentmonth方法中得到当前日期,获取当前年,当前月份,然后做了一系列字符串处理,目的是为了得到这样的值并且返回。
在数据库中,月份的值为201201,2012年1月这样的但是这里为什么要这样呢?这个时候就要看同比环比时候的表达式了。
当前月为基础对象,根据当前月延伸至上一个月,去年同月(当然也可以做当前日,当前季度,当前周,当前年的一系列分析)
当前月:
[Presentation Layer].[报表月份].[报表月份].[月]-> ?defaultmonth?
参数 ?defaultmonth?来自值提示
[Presentation Layer].[报表月份].[报表月份].[月]这个层级是来自
而不是月份code是number类型的对象,此处是memberUniqueName对象,数据格式为
[Presentation Layer].[报表月份].[报表月份].[月]->[all].[年].[年季度].[年月],所以上面的方法中做了一系列的字符串处理
目的就是利用当前日期得到符合当前月份的“【月】”的memberUniqueName值。
OK 在for循环里面遍历select,当值相等时默认selected.
需要注意的是当前月中的参数名称
[Presentation Layer].[报表月份].[报表月份].[月]-> ?defaultmonth?要和值提示的参数名称保持一致。每次选择的时候传递给当前月。
step2:创建报表页面
注意页面中的值提示参数名和提示页面保持一致。
step3:运行
效果1
效果2
效果3:
总结:看效果1与效果2得到2013年7月和2013年6月环比结果正确,看效果1与效果3得到2013年7月和2012年7月同比结果正确,问题得到解决。
cognos report同比环比以及默认为当前月分析的更多相关文章
- 再谈Cognos利用FM模型来做同比环比
很早之前已经讲过 <Cognos利用DMR模型开发同比环比>这篇文章里说的是不利用过滤器,而是采用 except (lastPeriods (-9000,[订单数据分析].[日期维度].[ ...
- cognos report上钻下钻报表处理方法(1)
cognos report开发中追溯行为,也可以称为上钻下钻行为大致遇到了两种情况 第一种:根据当前报表样式在维度范围内上钻下钻. 第二种:给追溯行为指定报表,传递参数. 可能还有其他情况,这里就不 ...
- Hive之同比环比的计算
Hive系列文章 Hive表的基本操作 Hive中的集合数据类型 Hive动态分区详解 hive中orc格式表的数据导入 Java通过jdbc连接hive 通过HiveServer2访问Hive Sp ...
- cognos report利用文本框提示优化日期维度
为了尽量减少手工对日期维度的维护,在日期维度表中年份已经到了2099年,把年份作为下拉框或者月份作为下拉框的时候,选择起来颇为麻烦(当然也可以在此基础之上设置默认为当前月) 如图:提示页面以及html ...
- cognos report在做同比时遇到的问题解决方法
本例就拿简单的一个模型作为测试: 订单中包括日期key,商品类型key 现在要实现每月的订单数,以及去年同期的订单数: step1:新建2个数据项 本月,去年同月 本月: [每日订单数据分析].[日期 ...
- Oracle分析函数/排名函数/位移函数/同比环比
分析函数 作用:分析函数可以在数据中进行分组,然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值.统计函数:MAX(字段名).MIN(字段名).AVG(字段名).SUM(字段名).CO ...
- Cognos Report Studio 链接查询需要注意的地方2
在Report Studio里面用SQL设计报表,查询2,查询3 要链接一般按条件 a1=b1 在选择链接方式需要注意的地方: 默认链接 外部链接 需要设置打开FM,打开报表设计引用的数据包(FM- ...
- MySQL统计同比环比SQL
大体思路: MySQL没有类似oracle方便的统计函数,只能靠自己去硬计算:通过时间字段直接增加年份.月份,然后通过left join关联时间字段去计算环比.同比公式即可 原始表结构: 求同比SQL ...
- 数据可视化之DAX篇(十二)掌握时间智能函数,同比环比各种比,轻松搞定!
https://zhuanlan.zhihu.com/p/55841964 时间可以说是数据分析中最常用的独立变量,工作中也常常会遇到对时间数据的对比分析.假设要计算上年同期的销量,在PowerBI中 ...
随机推荐
- Redis 服务器命令
1.BGREWRITEAOF 异步执行一个 AOF(AppendOnly File) 文件重写操作 2.BGSAVE 在后台异步保存当前数据库的数据到磁盘 3.CLIENT KILL [ip:port ...
- Acer宏碁暗影骑士3进阶版无法进入系统引导修复
1.刚开机时,按住alt不放,不停点击F10进入恢复系统: 2.点击疑难解答,选择cmd: 3.以下是cmd命令,//注释不要复制 c: //进入C盘 cd windows cd system32 b ...
- 错误:SSL peer shut down incorrectly
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 打开这个界面 ,修改一下.对照自己以前的没问题的项目.我的是3.3. 错误:Failed ...
- android 定时, 延时 任务
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 倒计时类 用 倒计时定时器CountDownTimer 延迟类 CountDownT ...
- 洛谷.2619.[国家集训队2]Tree I(带权二分 Kruskal)
题目链接 \(Description\) 给定一个无向带权连通图,每条边是黑色或白色.求一棵最小权的恰好有K条白边的生成树. \(Solution\) Kruskal是选取最小的n-1条边.而白边数有 ...
- hdu 4859 最小割
链接:点我 未懂
- MySQL的冷备份和热备份概念理解(转)
一.冷备份(off, 慢, 时间点上恢复) 冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库.冷备份是将关键性文件拷贝到另外位置的一种说法.对于备份数据库信息而言,冷备 ...
- WCF实现将服务器端的错误信息返回到客户端
转载:http://www.cnblogs.com/zeroone/articles/2299001.html http://www.it165.net/pro/html/201403/11033.h ...
- makfile.am 和makefile.in 的使用
参考 http://blog.csdn.net/vevenlcf/article/details/48134313 http://linux.chinaunix.net/techdoc/develop ...
- 转 ios给view设置圆角
// 圆角 userhead.layer.masksToBounds = YES; userhead.layer.cornerRadius = 6.0; userhead.layer.borderWi ...