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

然后指定参数的数据来源:

多选、全选:

效果图如下:

传入的参数在主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学习笔记 系列汇总 -- 持续更新中

时间: 2024-10-22 00:08:51

Dynamic CRM 2013学习笔记(二十六)Reporting Service报表 动态参数、参数多选全选、动态列、动态显示行字体颜色的相关文章

Dynamic CRM 2013学习笔记(十六)用JS控制Tab可见,可用

一个Form里经常会有好几个Tab,有时要根据一些条件设置哪些Tab可用,可见.下面就介绍下如何用JS对Tab进行控制. 1. 控制可见 function setTabVisableByName(tabName, flag) { var control = Xrm.Page.ui.tabs.get(tabName); control.setVisible(flag); } 这里flag是true或false 2. 控制可用 看了上面的可见代码,是不是以为可用也这么简单呢?其实我们把上面的setV

Dynamic CRM 2013学习笔记(十二)实现子表合计(汇总,求和)功能的通用插件

上一篇 Dynamic CRM 2013学习笔记(十一)利用Javascript实现子表合计(汇总,求和)功能 , 介绍了如何用js来实现子表合计功能,这种方法要求在各个表单上添加js方法,如果有很多实体要实现这个功能,有人觉得有点麻烦了,就不太喜欢这种方式,于是我写了一个通用的子表合计功能的通用插件,只用在注册插件时,填写不同的参数就可以实现这个功能了. 1. 首先看下效果: 2. 注册方法: 我们需要在子表上对create和update方法进行注册: 注册时要填写4个参数: 第一个参数是要被

Dynamic CRM 2013学习笔记(十)客户端几种查询数据方式比较

我们经常要在客户端进行数据查询,下面分别比较常用的几种查询方式:XMLHttpRequest, SDK.JQuery, SDK.Rest. XMLHttpRequest是最基本的调用方式,JQuery和Rest的二种方式其实也是用的XMLHttpRequest,只不过是把它封装了一下 JQuery和Rest二种方式的接口一样,所以调用方式也一样 1. XMLHttpRequest 定义 1: function ODataRetrieve(oDataString) { 2: var ServerU

Dynamic CRM 2013学习笔记(十五)报表入门、开发工具及注意事项

本文是关于CRM 2013报表开发入门介绍,包括开发工具的使用,以及不同于普通Reporting service的相关注意事项.   一.CRM报表简介 报表有两种,SQL-based报表和Fetch-based报表,区别如下: 区域 SQL-based 报表 Fetch-based 报表 Data Provider <DataProvider> 元素的值设置为SQL. 示例如下:<DataProvider>SQL</DataProvider> 报表RDL文件中的 &l

Dynamic CRM 2013学习笔记(十八)根据主表状态用JS控制子表自定义按钮

有时要根据主表的审批状态来控制子表上的按钮要不要显示,比如我们有一个需求审批通过后就不能再上传文件了. 首先打开Visual Ribbon Editor, 如下图,我们可以利用Enable Rules –> CustomRule 用js来控制按钮是否显示:   js function: 首先用odata取出主表的状态,然后根据主表的状态来判断是否显示: var approvalStatus = null; function controlUpload(){ var marketingPlan =

Dynamic CRM 2013学习笔记(十四)复制/克隆记录

经常有这样的需求,一个单据上有太多要填写的内容,有时还关联多个子单据,客户不想一个一个地填写,他们想从已有的单据上复制数据,克隆成一条新的记录.本文将介绍如何克隆一条记录,包括它的子单据以生成一条新的记录. 主要用到Microsoft.Xrm.Client.EntityExtensions.Clone方法来克隆数据,以及用OrganizationServiceContext来动态复制子单据的数据. 首先在界面上新加一个Clone的按钮,加一个new_clone的字段:点击按钮时,把new_clo

Dynamic CRM 2013学习笔记(十九)自定义审批流 - 效果演示

CRM的项目,审批流是一个必须品.为了更方便灵活地使用.配置审批流,我们自定义了一整套审批流.首先来看下它的效果: 1. 审批模板 这是一个最简单的审批流,首先指定审批实体,及相关字段,再配置流程节点,这里只有5个节点,而且没有规则节点(后面会介绍):   接着就是对上面的流程节点配置关系,这里就指定流程节点的走向:   运行一段时间后,可以查看审批的实例:   2. 操作审批流 审批流模板创建完后,我们就可以进行审批活动了. 开始的状态是Draft,这时可以提交审批: 点击Submit 按钮后

Dynamic CRM 2013学习笔记(十九)自定义审批流1 - 效果演示

CRM的项目,审批流是一个必须品.为了更方便灵活地使用.配置审批流,我们自定义了一整套审批流.首先来看下它的效果: 1. 审批模板 这是一个最简单的审批流,首先指定审批实体,及相关字段,再配置流程节点,这里只有5个节点,而且没有规则节点(后面会介绍): 接着就是对上面的流程节点配置关系,这里就指定流程节点的走向: 运行一段时间后,可以查看审批的实例: 2. 操作审批流 审批流模板创建完后,我们就可以进行审批活动了. 开始的状态是Draft,这时可以提交审批: 点击Submit 按钮后,会提示是否

Dynamic CRM 2013学习笔记(四十六)简单审批流的实现

前面介绍过自定义审批流: Dynamic CRM 2013学习笔记(十九)自定义审批流1 - 效果演示 Dynamic CRM 2013学习笔记(二十一)自定义审批流2 - 配置按钮 Dynamic CRM 2013学习笔记(三十二)自定义审批流3 - 节点及实体配置 Dynamic CRM 2013学习笔记(三十三)自定义审批流4 - 规则节点 -有分支的流程处理 Dynamic CRM 2013学习笔记(三十四)自定义审批流5 - 自动邮件通知 Dynamic CRM 2013学习笔记(三十