博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Reporting Services 2: 参数化报表
阅读量:4214 次
发布时间:2019-05-26

本文共 1579 字,大约阅读时间需要 5 分钟。

这篇随笔介绍一下Reporting Services的参数化报表(Parameterized Report)。

    按照报表内容的可变性,报表分为静态报表和参数化报表,数据驱动的参数化报表更符合人们的需求习惯。

    首先来看一下使用Reporting Services创建参数化报表的步骤:

    1、在项目AWReport中使用右键菜单“添加”→“新建项”→“报表”添加一个新的报表rptPR.rdl;

    2、在报表rptPR.rdl的“数据”选项卡中,单击数据集下来列表新建数据集DataEmployee(如图1所示),单击“通用查询设计器”切换到查询设计状态,添加表HumanResources.Employee,并选择所有列作为输出。

图1 新建数据集

    3、在报表rptPR.rdl的设计状态(“数据”或“布局”选项卡下),使用菜单“报表”→“报表参数”,启动“报表参数”对话框,为报表添加参数并为参数指定相应的“数据类型”和“提示”,如表1所示。不同数据类型的参数在报表中显示为不同的控件,如Boolean类型的参数显示为标识为True和False的两个复选框,而DateTime类型显示为一个DateTimePicker;而“提示”标明的是这些控件前面的标签。

参数名称

数据类型
提示

pTitle

String
头衔

pMStatus

String
婚姻状况

pGender

String
性别

pSFlag

Boolean
是否带薪

pBDate

DateTime
生日

表1 参数名称、数据类型和提示的设置

    4、切换到报表的“数据”选项卡,为相应字段添加图2所示的筛选条件。

 

图2 为字段添加参数作为筛选条件

    5、切换到报表的“布局”选项卡,为报表设计图3所示的布局。

图3 报表布局

    6、在预览状态下,在报表中显示的参数项目中为参数指定不同的值,就可以看到图4所示的参数化报表了。

 

图4 预览状态下的参数化报表

    “婚姻状况”的实际取值有两种——M(Married,已婚的)和S(Single或Sole,未婚的),而对于用户来说,该参数的值使用文本框来接受输入显然是不合适的,例如输入单词的全拼或Unmarried的第一个字母U就查不出任何结果,可以考虑在“报表参数”对话框的“可用值”区域进行图5所示的设置,这样“婚姻状况”参数的输入就可以使用下拉列表来进行了。“性别”参数应该进行同样的设置。

 

图5 为“婚姻状况”设置可用值

    如果用户对于公司雇员的头衔不熟悉或者头衔有不同的叫法,同样会带来上面的困扰,而“头衔”字段的值并不是固定的,系统维护时很可能出现增加或减少的情况,这时候可以考虑从查询中为该参数指定“可用值”。需要注意的是,如果使用同一数据集DataEmployee中的Title字段作为可用值的来源,而Title字段又是第一个参数时会出现前向依赖错误,因为此时Title字段的取值是由后面的参数决定的;而如果将Title字段作为最后一个参数时,每次更改其它参数的值都会引起Title参数下拉列表中数据的刷新和变动(这个可用来做如省/市/县等的联动)。此时,应该考虑,通过图1所示的方法另外新建一个数据集DataTitle,并指定其数据来源为:

SELECT Distinct Title FROM HumanResources.Employee

    然后按照图6所示的设置指定“头衔”参数的可用值。

 

图6 为“头衔”设置可用值

    另外,可以为每个参数指定“默认值”,减少常见查询时的数据输入。

    报表在一个Web项目中的显示如图7所示。

 

图7 Web项目中显示的参数化报表(点击小图看大图)

    Reporting Services在一定程度上满足了用户对参数化报表的需求,但是也存在一些可以改进的地方,如一旦定义参数就不能忽略参数的值进行报表的查看。

转载地址:http://xrfmi.baihongyu.com/

你可能感兴趣的文章
《redis in action》key的自动过期
查看>>
《redis in action》redis持久化简介
查看>>
Oracle RAC Failover 详解
查看>>
批处理 自动修改 IP 地址
查看>>
Oracle RAC LoadBalance
查看>>
v$sql,v$sqlarea,v$sqltext 和 v$sql_plan 说明
查看>>
ORA-31623 When Submitting a Datapump Job [ID 308388.1]
查看>>
Oracle SYSAUX 表空间 说明
查看>>
RAC 安装patch 后启动实例 报错 ORA-00439 feature not enabled- Real Application Clusters 解决方法
查看>>
On RAC, expdp Removes the Service Name [ID 1269319.1]
查看>>
Important Changes to Oracle Database Patch Sets Starting With 11.2.0.2 [ID 1189783.1]
查看>>
Oracle alert log ALTER SYSTEM SET service_names='','SYS$SYS.KUPC$C_...' SCOPE=MEMORY SID='' 说明
查看>>
Oracle latch:library cache 导致 数据库挂起 故障
查看>>
Openfiler 配置 NFS 示例
查看>>
Oracle 11.2.0.1 RAC GRID 无法启动 : Oracle High Availability Services startup failed
查看>>
Oracle 18c 单实例安装手册 详细截图版
查看>>
Oracle Linux 6.1 + Oracle 11.2.0.1 RAC + RAW 安装文档
查看>>
Oracle 11g 新特性 -- Online Patching (Hot Patching 热补丁)说明
查看>>
Oracle 11g 新特性 -- ASM 增强 说明
查看>>
Oracle 11g 新特性 -- Database Replay (重演) 说明
查看>>