Dynamic CRM 2013学习笔记(二十六)报表设计:Reporting Service报表 动态参数、参数多选全选、动态列、动态显示行字体颜色
上次介绍过CRM里开始报表的一些注意事项:Dynamic CRM 2013学习笔记(十五)报表入门、开发工具及注意事项,本文继续介绍报表里的一些动态效果:动态显示参数,参数是从数据库里查询出来的;参数可以多选或全选;动态地显示列,列不是固定的;根据某一字段的值来动态地显示整行字体的颜色。
下面介绍详细的方法:
一、动态参数、参数多选全选
动态参数:
首先定义一个Dataset:
SELECT DISTINCT new_countryId, new_codename AS name FROM new_country WHERE new_codename IS not null
然后指定参数的数据来源:

注意,这里参数Value 字段一定要用主健,也就是说如果value也用name,将查询不到结果。
多选、全选:

效果图如下:

传入的参数在主Dataset里通过in来查询:
ct.new_countryid IN ( @country )
二、 动态列
最近有个需求,要把全年所有的星期相关的数据查询出来,每个月的最后一周后面显示本月的合计。月是固定的,好处理,但每个月有几周却不是固定的,这时候就没办法固定的查询出数据,然后直接拖到报表里了。解决思路如下:
1. 列名和列各定义一个Dataset, 先看下列名的定义:
先定义一个临时表,每月最多5周,所以每月前面都定义5周。
--创建临时表,用来存储活动的周名称
CREATE TABLE #weekColumn
(
Start VARCHAR(10) ,
W1 VARCHAR(100) ,
W1Remark VARCHAR(100) ,
W2 VARCHAR(100) ,
W2Remark VARCHAR(100) ,
W3 VARCHAR(100) ,
W3Remark VARCHAR(100) ,
W4 VARCHAR(100) ,
W4Remark VARCHAR(100) ,
W5 VARCHAR(100) ,
W5Remark VARCHAR(100) ,
Month1 VARCHAR(100) ,
W6 VARCHAR(100) ,
W6Remark VARCHAR(100) ,
W7 VARCHAR(100) ,
W7Remark VARCHAR(100) ,
W8 VARCHAR(100) ,
W8Remark VARCHAR(100) ,
W9 VARCHAR(100) ,
W9Remark VARCHAR(100) ,
W10 VARCHAR(100) ,
W10Remark VARCHAR(100) ,
Month2 VARCHAR(100) ,
...
然后遍历所有月,根据规定的格式,定义周、月的列名:
DECLARE month_cursor CURSOR
FOR
SELECT new_monthid ,
new_name ,
new_month
FROM filterednew_month
WHERE new_year = YEAR(GETDATE())
ORDER BY new_name
OPEN month_cursor
FETCH NEXT FROM month_cursor INTO @monthid, @monthName, @monthNo
WHILE @@FETCH_STATUS = 0
BEGIN
SET @index = ( @monthNo - 1 ) * 5 + 1
-- 3. get all weeks
DECLARE week_cursor CURSOR
FOR
SELECT new_name ,
new_week_no
FROM filterednew_week
WHERE new_monthid = @monthid
OPEN week_cursor
FETCH NEXT FROM week_cursor INTO @weekName, @weekNo
WHILE @@FETCH_STATUS = 0
BEGIN
SET @sql = 'W' + CAST(@index AS VARCHAR(100));
SET @sqlName = 'W' + CAST(@index AS VARCHAR(100)) + 'Remark';
SET @sql = ' update #weekColumn set ' + @sql + '='''
+ @weekName + '''' + ',' + @sqlName + '=''Remark'''
EXEC(@sql);
SET @index += 1
FETCH NEXT FROM week_cursor INTO @weekName, @weekNo
END
CLOSE week_cursor
DEALLOCATE week_cursor
SET @sql = 'Month' + CAST(@monthNo AS VARCHAR(100));
SET @sql = ' update #weekColumn set ' + @sql + '=''' + @monthName
+ ''''
EXEC(@sql);
SET @index += 1
FETCH NEXT FROM month_cursor INTO @monthid, @monthName, @monthNo
END
CLOSE month_cursor;
DEALLOCATE month_cursor;
最后查询这个临时表就可以得到所有的列名:
SELECT *
FROM #weekColumn;
2. 列值的Dataset定义:
首先也是定义包含所有周、月的临时表,也是每月前定义5周,跟列名对应起来。
接着,遍历所有月,确定当前数据是本月的哪一周:
--查找是本月的第几周
PRINT @monthNo
SELECT @whichWeek = rn
FROM ( SELECT ROW_NUMBER() OVER ( ORDER BY w.new_week_no ) RN ,
w.new_week_no
FROM filterednew_week w
JOIN filterednew_month m ON w.new_monthid = m.new_monthId
WHERE m.new_month = @monthNo
) mw
WHERE mw.new_week_no = @weekNo
再确定数据插入的位置:
-- 确定插入位置
SET @index = ( @monthNo - 1 ) * 5 + @whichWeek
PRINT @index
PRINT @monthNo
PRINT @whichWeek
SET @sqlOrderQty = 'W' + CAST(@index AS VARCHAR(100))
+ 'OrderQty';
SET @sqlQty = 'W' + CAST(@index AS VARCHAR(100)) + 'Qty';
SET @sqlRemark = 'W' + CAST(@index AS VARCHAR(100)) + 'Remark';
SET @sql = ' update #weekColumn set ' + @sqlOrderQty + '='
+ CAST(ISNULL(@orderQty, '0') AS VARCHAR(100)) + ','
+ @sqlQty + '=' + CAST(ISNULL(@qty, 0) AS VARCHAR(100))
+ ',' + @sqlRemark + '=''' + ISNULL(@remark, '') + ''''
+ ' WHERE ReportIndex = '
+ CAST(@ReportIndex AS VARCHAR(100));
PRINT @sql
EXEC(@sql);
3. 报表上处理
列名要用简单处理下,要用列名的Dataset,如下显示的第一周的列名:
=First(Fields!W1.Value, "columns_DataSet")
另外,每个月的前一周有可能是要hide的,因为有可能没有第5周,右健整个列,选择 Column Visibility:

如果没有值就hide起来:

=iif(isnothing(First(Fields!W5.Value, "columns_DataSet")),true,false)
到此,动态显示列完成。
三、 动态显示行字体颜色
首先选中整个行:

然后在行的Font-> Color里定义颜色:

=IIF(Fields!versions.Value = "Demand Plan", "Black", "Green")
注意 Black, Green都要带引号。
Dynamic CRM 2013学习笔记 系列汇总 -- 持续更新中
Dynamic CRM 2013学习笔记(二十六)报表设计:Reporting Service报表 动态参数、参数多选全选、动态列、动态显示行字体颜色的更多相关文章
- Dynamic CRM 2013学习笔记(十六)用JS控制Tab可见,可用
一个Form里经常会有好几个Tab,有时要根据一些条件设置哪些Tab可用,可见.下面就介绍下如何用JS对Tab进行控制. 1. 控制可见 function setTabVisableByName( ...
- Dynamic CRM 2013学习笔记(十二)实现子表合计(汇总,求和)功能的通用插件
上一篇 Dynamic CRM 2013学习笔记(十一)利用Javascript实现子表合计(汇总,求和)功能 , 介绍了如何用js来实现子表合计功能,这种方法要求在各个表单上添加js方法,如果有很多 ...
- Dynamic CRM 2013学习笔记(十)客户端几种查询数据方式比较
我们经常要在客户端进行数据查询,下面分别比较常用的几种查询方式:XMLHttpRequest, SDK.JQuery, SDK.Rest. XMLHttpRequest是最基本的调用方式,JQuery ...
- Dynamic CRM 2013学习笔记(十五)报表设计:报表入门、开发工具及注意事项
本文是关于CRM 2013报表开发入门介绍,包括开发工具的使用,以及不同于普通Reporting service的相关注意事项. 一.CRM报表简介 报表有两种,SQL-based报表和Fetch-b ...
- Dynamic CRM 2013学习笔记(十四)复制/克隆记录
经常有这样的需求,一个单据上有太多要填写的内容,有时还关联多个子单据,客户不想一个一个地填写,他们想从已有的单据上复制数据,克隆成一条新的记录.本文将介绍如何克隆一条记录,包括它的子单据以生成一条新的 ...
- Dynamic CRM 2013学习笔记(十八)根据主表状态用JS控制子表自定义按钮
有时要根据主表的审批状态来控制子表上的按钮要不要显示,比如我们有一个需求审批通过后就不能再上传文件了. 首先打开Visual Ribbon Editor, 如下图,我们可以利用Enable Rules ...
- Dynamic CRM 2013学习笔记(十九)自定义审批流1 - 效果演示
CRM的项目,审批流是一个必须品.为了更方便灵活地使用.配置审批流,我们自定义了一整套审批流.首先来看下它的效果: 1. 审批模板 这是一个最简单的审批流,首先指定审批实体,及相关字段,再配置流程节点 ...
- Dynamic CRM 2013学习笔记 系列汇总
这里列出所有 Dynamic CRM 2013学习笔记 系列文章,方便大家查阅.有任何建议.意见.需要,欢迎大家提交评论一起讨论. 本文原文地址: Dynamic CRM 2013学习笔记 系列汇总 ...
- Dynamic CRM 2013学习笔记(二十)字段改变事件的二种实现方法
CRM里有二种方式实现字段change事件,一种是在form里,一种完全通过js来实现.本文介绍下二者的用途及区别. 1. Form里用法 这种方式估计其实也是添加一个js的function. 这种方 ...
随机推荐
- Android开发者必须掌握的知识技能清单
1.Android平台原理机制.客户端性能优化.软件架构设计,熟悉Android应用开发框架,能独立开发高性能的Android应用 2.同步.异步.多线程.跨进程,数据结构和计算机系统和NDK即c++ ...
- redis集群出现JedisNoReachableClusterNodeException异常(No reachable node in cluster)
上午午好好的,突然抛了如下异常: Exception in thread "main" redis.clients.jedis.exceptions.JedisNoReachabl ...
- 使用阿里Docker镜像加速器加速
在阿里开发者平台注册开发者账号 https://dev.aliyun.com/search.html 注册之后可以访问Docker镜像服务 https://cr.console.aliyun.com/ ...
- (转载)iOS系统Crash文件分析方法
转自: http://ios-iphone.diandian.com/post/2012-05-18/19440182 Xcode 4.3的symbolicatecrash的位置和老版本的不一致了. ...
- 循序渐进Python3(五) -- 初识模块
什么是模块? 模块,用一组代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能 ...
- Tornado 异步客户端
前言 Tornado是很优秀的非阻塞式服务器,我们一般用它来写Web 服务器,据说知乎就是用Tornado写的. 如果对tornado源码不是很了解,可以先看一下另一篇文章: http://yunji ...
- DUILIB CDialogBuilder 使用问题
频繁调用CDialogBuilder的create接口创建同一个配置文件,会报异常: 正常的处理方式如下: if (!m_dlgBuilder.GetMarkup()->IsValid()) { ...
- Asp.net web api部署在某些服务器上老是404
asp.net web api部署在Windows服务器上后,按照WebAPI定义的路由访问,老是出现404,但定义一个静态文件从站点访问,却又OK. 这时,便可以确定是WebAPI路由出了问题,经调 ...
- 2d,3d中旋转推导
二维绕原点旋转,其实点为(x,y),旋转角度为黄色标注的角度. 推导过程如下: x' = r cos(al+be); y' = r sin(al+be);x '= rcosalcosbe-rsinal ...
- coreseek实战(二):windows下mysql数据源部分配置说明
coreseek实战(二):windows下mysql数据源部分配置说明 关于coreseek在windows使用mysql数据源的配置,以及中文分词的详细说明,请参考官方文档: mysql数据源配置 ...