上次介绍过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报表 动态参数、参数多选全选、动态列、动态显示行字体颜色的更多相关文章

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

    一个Form里经常会有好几个Tab,有时要根据一些条件设置哪些Tab可用,可见.下面就介绍下如何用JS对Tab进行控制. 1. 控制可见   function setTabVisableByName( ...

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

    上一篇 Dynamic CRM 2013学习笔记(十一)利用Javascript实现子表合计(汇总,求和)功能 , 介绍了如何用js来实现子表合计功能,这种方法要求在各个表单上添加js方法,如果有很多 ...

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

    我们经常要在客户端进行数据查询,下面分别比较常用的几种查询方式:XMLHttpRequest, SDK.JQuery, SDK.Rest. XMLHttpRequest是最基本的调用方式,JQuery ...

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

    本文是关于CRM 2013报表开发入门介绍,包括开发工具的使用,以及不同于普通Reporting service的相关注意事项. 一.CRM报表简介 报表有两种,SQL-based报表和Fetch-b ...

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

    经常有这样的需求,一个单据上有太多要填写的内容,有时还关联多个子单据,客户不想一个一个地填写,他们想从已有的单据上复制数据,克隆成一条新的记录.本文将介绍如何克隆一条记录,包括它的子单据以生成一条新的 ...

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

    有时要根据主表的审批状态来控制子表上的按钮要不要显示,比如我们有一个需求审批通过后就不能再上传文件了. 首先打开Visual Ribbon Editor, 如下图,我们可以利用Enable Rules ...

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

    CRM的项目,审批流是一个必须品.为了更方便灵活地使用.配置审批流,我们自定义了一整套审批流.首先来看下它的效果: 1. 审批模板 这是一个最简单的审批流,首先指定审批实体,及相关字段,再配置流程节点 ...

  8. Dynamic CRM 2013学习笔记 系列汇总

    这里列出所有 Dynamic CRM 2013学习笔记 系列文章,方便大家查阅.有任何建议.意见.需要,欢迎大家提交评论一起讨论. 本文原文地址: Dynamic CRM 2013学习笔记 系列汇总 ...

  9. Dynamic CRM 2013学习笔记(二十)字段改变事件的二种实现方法

    CRM里有二种方式实现字段change事件,一种是在form里,一种完全通过js来实现.本文介绍下二者的用途及区别. 1. Form里用法 这种方式估计其实也是添加一个js的function. 这种方 ...

随机推荐

  1. 解决IE9下JQuery的ajax失效的问题

    jquery ajax在跨域访问post请求的时候,ie9以下无效(包括ie9)   1. 设置浏览器安全属性,启用[通过域访问数据源]选项,如图:

  2. php乱码解决

    代码示例: <?phpheader("Content-type: text/hml; charset=utf-8");echo "holl 欢迎光临小站,现在正在建 ...

  3. mysql数据类型最大长度记录

    MySQL中各数据类型的取值范围 转在这里,慢慢记下来. TINYINT -128 - 127 TINYINT UNSIGNED 0 - 255 SMALLINT -32768 - 32767 SMA ...

  4. phpstorm

    9XVKERIY9F-eyJsaWNlbnNlSWQiOiI5WFZLRVJJWTlGIiwibGljZW5zZWVOYW1lIjoiYXNoZXIgY2hlbiIsImFzc2lnbmVlTmFtZ ...

  5. C++中的预处理

    一.预处理的由来:      在C++的历史发展中,有很多的语言特征(特别是语言的晦涩之处)来自于C语言,预处理就是其中的一个.C++从C语言那里把C语言预处理器继承过来(C语言预处理器,被Bjarn ...

  6. ubuntu 14 配置JDK

    1. 下载JDK http://www.oracle.com/technetwork/cn/java/javase/downloads/index.html 下载后的保存地址: /home/root1 ...

  7. 【C#】 一些不常用,很容易混淆的知识点

    [C#] 一些不常用但很容易混淆的知识点 1. 访问修饰符 internal ,译为内部的, 在同一个程序集中可访问,它的内部是相对与程序集的,可不能想当然了 2. String.Compare 这个 ...

  8. 【BZOJ2595】游览计划(状压DP,斯坦纳树)

    题意:见题面(我发现自己真是越来越懒了) 有N*M的矩阵,每个格子有一个值a[i,j] 现要求将其中的K个点(称为关键点)用格子连接起来,取(i,j)的费用就是a[i,j] 求K点全部连通的最小花费以 ...

  9. docker学习使用

    安装什么的就略过了,之前已经整理过,这里就说说自己使用中的一些东西,也是初用,记录下(现在使用win10 64位,使用Docker for Windows直接安装就好[需要专业版win10安装hype ...

  10. servlet二

    ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些初始 ...