【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 的图书详情—>下载资源
【Reporting Services 报表开发】— 级联式参数设置的更多相关文章
- 【Reporting Services 报表开发】— 交互式报表
我们知道,界面是人与系统间的对话方式,当使用者面对的是冷冰冰的界面,不但会造成使用者对于系统的热情减低,也会因为不便而产生诸多抱怨.尤其像报表时企业内几乎每日都会使用到的工具,因此,如何让使用者可以再 ...
- 【Reporting Services 报表开发】— 数据表的使用
一.打开 SQL Server Business Intelligence Development Studio,新建项目—>商业智能项目—> 报表服务器项目,命名为CH3 二.在报表文件 ...
- 【Reporting Services 报表开发】— 页码编列
一.打开 SQL Server Business Intelligence Development Studio,新建项目—>商业智能项目—> 报表服务器项目,命名为CH4 二.在报表文件 ...
- 【Reporting Services 报表开发】— 矩阵的使用
矩阵,相较于数据表示一维的数据,只能指定固定的数据列,来呈现动态的明细数据行,所以,它可以说是种二维的数据展现形式,让我们能够很容易地从数据行和数据集的交替中查看对应的汇总信息.像SQL Server ...
- Reporting Services报表常用的URL参数
http://blog.sina.com.cn/s/blog_5ef7acf5010118a5.html Reporting Services报表常用的URL参数 (2012-03-01 20:57: ...
- 【Reporting Services 报表开发】— 如何根据明细的行数实现分页(比如每隔5行分页)
一.新建报表:对于初学者可以参考我前面的文章[Reporting Services 报表开发]— 总结 如图1: 图 1 二.选择 new_name文本框—>添加组—>选择行组中的父组.具 ...
- 【Reporting Services 报表开发】— 表达式
一.常用的SSRS原始函数可以打开文本框的表达式中看到,如图1 图1 如下为SSRS中设计报表时常用的运算函数: 运算符/函数 说明 + 前后位数字则为加法,前后为字符串则为链接符号 - 数值减法 * ...
- 【Reporting Services 报表开发】— 数据表存储格式修改
文本框 Format属性:日期:输入d(表示简易日期).2007/5/1 0:00:00 输入d之后 变成 2007/5/1 金额:输入C0(表示货币),系统会根据设定值产生对应的货币符号,至于0 ...
- 【Reporting Services 报表开发】— 怎么根据当前表单的guid作为参数查询相关数据?
select AId from FilteredA as CRMAF_FilteredA 用这个 作为一个DataSet1 , 然后添加在报表里面添加一个参数 @AId,设置的默认的查询为前面Data ...
随机推荐
- Java 集合深入理解(14):Map 概述
点击查看 Java 集合框架深入理解 系列, - ( ゜- ゜)つロ 乾杯~ 终于把 List 常用的几种容器介绍完了,接下来开始 Map 的相关介绍. 什么是 Map Java 中的 Map 接口 ...
- latex figure \label 放在\caption 后
http://www.cnblogs.com/loca/p/4264686.html latex figure \label 放在\caption 后,否则将显示\section 或者\subsect ...
- iptables导致数据包过多时连接失败
前几天做服务器压力测试,本地10个线程不停的去向服务器建立连接,然后请求数据,然后连接再关闭,程序每运行几万次之后就会发现客户端程序没办法connect服务器,connect超时. 一开始怀疑是自己服 ...
- 跳出frameset框架
很多网页都是框架结构的,在很多的情况下会通过按钮点击事件或链接,跳出框架转到其它界面.例如说点击“注销登录”返回到登录界面. 一.通过运行脚本跳出框架有以下几种写法: 1.<script lan ...
- MariaDB exists 学习
MariaDB exists 学习 exists对外表用loop逐条查询,每次查询都会查看exists的条件语句,当 exists里的条件语句能够返回记录行时(无论记录行是的多少,只要能返回),条件就 ...
- HttpResponse的Close和End 区别
转载自:http://blog.sina.com.cn/s/blog_702c390c0100mlhi.html 最近启用了IIS上的压缩功能,但是测试系统上某模块变得不可用了.该模块采用AJAX技术 ...
- Codeforces Round #376 (Div. 2) A B C 水 模拟 并查集
A. Night at the Museum time limit per test 1 second memory limit per test 256 megabytes input standa ...
- ZOJ 1042 W’s Cipher
原题链接 题目大意:按照规则解码.26个字母分成三组,每一组按照顺时针移位编码.现在已知移动的位数,要求解码. 解法:以前看过一本古典密码学的书,百度贴吧密码吧也有很多经典的加密方法,想什么凯撒移位. ...
- Fresco好案例
http://www.open-open.com/lib/view/open1436094840774.html
- 第三篇T语言热键启动方法
热键控件 热键控件的使用方法 第一步:选择热键添加到面板上. 第二步:热键控件属性选择热键键值. 第三步:添加热键事件功能. 热键模式的选择 1.普通模式 2.软件模式 3.硬件模式 脚本的基本操作 ...