zoukankan      html  css  js  c++  java
  • 【Reporting Services 报表开发】— 级联式参数设置

     级联式参数设置

        再清楚的菜单,只要遇到选择项目一多的时候,难免会让人眼花缭乱,而找不到该选的选项。举例来说,像是零售业动辄万种商品品类,如果希望快速的选择到希望查看的产品品类时,就需要更有效率的搜索方式。

       当选择西选项过多时,可以用其他参数作为“预选”的项目,当前置参数被选定之后,就会同时限制了后设参数的值域,如此一来,即可做到快速选项减量的目的,例如,选择了“产品大分类”为灯具后,那么“产品中分类”就只会筛选出在这个大分类下的项目,而这项功能称之为“级联式参数(Cascading Parameter)”,具体看下面的示例。

    一、打开 SQL Server Business Intelligence Development Studio,新建项目—>商业智能项目—> 报表服务器项目,命名为CH4

    二、在报表文件下下面,新建报表,名称为CascadingParameterReport,具体如图1和图2

      

                                                              图1 

     

                                                                                                   图2

     三、添加数据源,选择的数据库名称为ASIAMINER_SSRS,具体如下图3,4,5,6:

    1.右击数据源,添加数据源

       

                     图3

                                                           图4

     

                                                                    图5

                          

      

                                       图6

     2.添加数据集,需要用到的SQL语句,如下:

    --ProductSubcategoryList
    select
    productsubcategory_key,
    productsubcategory_name
    from dim_productsubcategory
    where productcategory_key in (@productcategory_key)
    --ProductCategoryList
    select 
    productcategory_key,
    productcategory_name
    from dim_productcategory

    如图7和图8:

                                                        图7 

                                              图8 

    设置完成之后,报表窗口显示如下

               图9

      

     四、TIP 级联参数的优先级:在树状目录下的参数顺序表示他们被产生的顺序,因此需要注意到逻辑的合理性,例如,本示例中我们应该是先选择产品大类参数,才会选择产品中类参数,因此需要特别注意优先级。

    1.接下来,设置产品大类以及产品种类这两个参数。首先开启productcategory_key参数的属性对话框,除了在“常规”标签页中将它的“提示”改成“产品大类”,以及勾选“允许多个值”之外,同时切换至“可用值”标签页,勾选“从查询中取得值”,并且将数据集切换为“ProductCategoryList”,将值字段设为“productcategory_key”(实际传递至where条件的参数值),将标签字段设为“productcategory_name”(使用者看的董的内容),具体如图10和图11:

                                                          图10

                                      图11

    2.添加productsubcategory_key参数,首先开启productsubcategory_key参数的属性对话框,除了在“常规”标签页中将它的“提示”改成“产品中类”,以及勾选“允许多个值”之外,同时切换至“可用值”标签页,勾选“从查询中取得值”,并且将数据集切换为“ProductSubcategoryList”,将值字段设为“productsubcategory_key”(实际传递至where条件的参数值),将标签字段设为“productsubcategory_name”(使用者看的董的内容),具体如图12和图13:

                                                   图12

                                         图13

    添加之后参数之后,报表窗口如下图14:

                   图14

    五、设置完成之后,将报表切换至“预览”标签页预览报表,首先,会看到只有第一个参数可以利用下拉菜单选择,产品中类的菜单式被锁住而无法使用的(如图15)。当产品大类选单选值(灯具)之后,产品中类仅显示灯具类的中分类项目,当产品大类切换为其他项目时,产品中类也会跟着联动(如图16)。

     

                                                   图15

                                                  图16

    这种级联式的报表不但方便使用者勾选,同时还可以集成企业内部的权限层级,作到复杂的权限控制。

    参考书籍《SQL Server 2008 R2  Reporting Services 报表服务》

    需要下载的数据库和SQL脚本:http://www.wsbookshow.com/bookshow/kjlts/jsj/kfzj/11395.html 的图书详情—>下载资源

  • 相关阅读:
    python的select和epoll
    ibatis annotations 注解方式返回刚插入的自增长主键ID的值
    java web 项目中获取当前路径的几种方法
    Servlet的监听器
    mybatis-配置文件mybatis-config.xml
    数据库死锁
    JDBC控制事务
    server.xml 解析
    linux下Tomcat 安装后执行startup.sh,出现– Cannot find …bin/catalina.sh
    jni 类初始化失败(nested exception is java.lang.NoClassDefFoundError)
  • 原文地址:https://www.cnblogs.com/allenhua/p/3764428.html
Copyright © 2011-2022 走看看