微软SQL Server 2000 Reporting Services介绍(五)

原创 2004年01月08日 13:57:00

微软SQL Server 2000 Reporting Services介绍()

 

 

[摘要    ] 本文主要介绍了如何综合利用Report Designer和修改rdl文件来快速、灵活的实

现报表氐憬步饬似渲?lt;/SPAN>Matrix格式和Toggle功能的实现

[关键字] Reporting Services,.NET Framework.,rdl文件,Matrix格式,Toggle功能

 

n       如何实现Matrix

上图是Reporting Services中提供的一个例子,纵向为一个公司的产品类别和子类别,横向为年份和季度,这种显示模式在很多的报表中都可以套用,例如一般的集团公司会在纵向显示出所有分子公司和部门。下面从rdl文件的角度分析该例子是如何实现的,首先来看看其中的查询语句

    <Query>

        <DataSourceName>AdventureWorks</DataSourceName>//指定数据源名称

        <CommandText>SELECT     ProductCategory.Name AS ProdCat, //产品类别ProductSubCategory.Name AS SubCat, //产品子类别

DATEPART(yy, SalesOrderHeader.OrderDate) AS OrderYear, //年份

'Q' + DATENAME(qq, SalesOrderHeader.OrderDate) AS OrderQtr, //季度SUM(SalesOrderDetail.UnitPrice * SalesOrderDetail.OrderQty) AS Sales//销售数据

     

FROM         ProductSubCategory INNER JOIN

                     ………………….

WHERE     (SalesOrderHeader.OrderDate BETWEEN '1/1/2002' AND '12/31/2003')//时间范围

//这里的GROUP BY保证数据的层次关系

GROUP BY

DATEPART(yy, SalesOrderHeader.OrderDate), ProductCategory.Name, ProductSubCategory.Name, 'Q' + DATENAME(qq,

                      SalesOrderHeader.OrderDate), ProductSubCategory.ProductSubCategoryID</CommandText>

               下面再来看看rdl中是如何指定季度列隐藏在年份下面的

<ColumnGrouping>

            <DynamicColumns>

              <Grouping Name="OrderQtr">//该动态列的名称为OrderQtr

                <GroupExpressions>

                  <GroupExpression>=Fields!OrderQtr.Value</GroupExpression>

                </GroupExpressions>

              </Grouping>

              <Visibility>//这一段实现了季度列的隐藏,并和OrderYear建立了Toggle关系,仅仅三行代码就实现了一种复杂的数据层次关系,可见Reporting Services的功能之强大.

                <ToggleItem>OrderYear</ToggleItem>

                <Hidden>true</Hidden>

</Visibility>

同样,产品类别和产品子类别也是这样建立关系的,虽然通过.NET开发环境可以很容易的实现该功能,但如果能够熟练的修改rdl文件来实现功能,能节约大量的时间。

 

下面看看该报表是如何显示销售数据的

  <MatrixRows>

          <MatrixRow>

            <MatrixCells>

              <MatrixCell>

                <ReportItems>

                  <Textbox Name="Sales">

                    <Style>

                      <BorderStyle>

                        <Default>Solid</Default>

                      </BorderStyle>

                      <PaddingLeft>2pt</PaddingLeft>

                      <Format>$#,###</Format>//这里指定了销售数据显示的格式,包括美元符号和千分位,从这里入手修改为人民币符号是比较快捷的

                      <BackgroundColor>White</BackgroundColor>

                      <FontSize>9pt</FontSize>

                      <PaddingRight>2pt</PaddingRight>

                    </Style>

                    <Value>=Sum(Fields!Sales.Value)</Value>//显示销售数据的和

                  </Textbox>

 

好了,分析完这些关键代码,整个Company Sales.rdl(可以在MS SQL Server安装目录下找到)就很好理解了,其他的许多代码大部分都是设置报表格式的,如果改写的时候觉的这个例子的格式比较赏心悦目,完全可以把其中的<Style>部分代码拿出来贴上去,如果依靠.NET中的Report Designer来做就不那么灵活了。经过一段时间的使用,感觉比较好的方式是,先通过Report Designer把报表的框架做出来,然后如果要做一些细节的修改,就直接修改rdl文件好了,rdl修改后,返回到Report Designer中进行预览.

安装Reporting Service 2012

安装Reporting Service 2012   MSDN相关内容请参见: http://msdn.microsoft.com/zh-cn/library/ms143711%28v=sq...
  • albert528108
  • albert528108
  • 2016年09月29日 10:00
  • 996

微软SQL Server 2000 Reporting Services介绍

微软SQL Server 2000 Reporting Services介绍   [摘要    ] 本文说明了Reporing Services安装时要注意的问题,另外根据Reporing Servi...
  • UFO_CSDN
  • UFO_CSDN
  • 2004年01月06日 22:06
  • 1850

SQL Server Reporting Services 远程匿名访问解决办法

SQL Server Reporting Services 并非专门设计用于 Internet 报表部署方案,但是您可以成功地将 Reporting Services 放置于面向 Internet 的...
  • emailqjc
  • emailqjc
  • 2010年09月16日 11:57
  • 5470

SQL Server 2008 Reporting Services报表中文乱码问题

在使用SQL Server 2008 Reporting Services的报表设计器生成报表时,某些中文会出现乱码,如下图"Date"列:   修改方法: 在"设计"视图中...
  • tianlianchao1982
  • tianlianchao1982
  • 2016年05月10日 20:24
  • 1137

配置Reporting Service 2012

1. Reporting Services Configuration Manager   步骤1:点击“Start”,“All Programs”,“Microsoft SQL Server 2...
  • albert528108
  • albert528108
  • 2016年09月29日 09:58
  • 1774

教程:如何查找并启动 Reporting Services 工具 (SSRS)

本教程介绍了用于配置报表服务器、管理报表服务器内容和操作以及创建并发布分页和移动 Reporting Services 报表的工具。 如果你已经熟悉了这些工具,你可以转到其他教程学习有关使用 Repo...
  • qq_35019337
  • qq_35019337
  • 2017年03月27日 16:12
  • 846

通用报表解决方案:SQL Server Reporting Services是什么

SQL Server Reporting Services是什么?     SQL Server Reporting Services(SSRS),微软企业级报表平台,和SQL Server Int...
  • moon66sun
  • moon66sun
  • 2012年03月28日 16:46
  • 1048

SQL Server Reporting Service SP1发布

SQL Server Reporting Service SP1发布   Microsoft? SQL Server? 2000 Reporting Services 的该 Service Pack ...
  • MasterLRC
  • MasterLRC
  • 2004年07月14日 10:52
  • 1146

Microsoft Dynamics CRM 2013 安装 报表服务出现“ SQL Server Reporting Services 帐户是本地用户且不受支持 ”错误的解决方法

Microsoft Dynamics CRM 2013 安装 报表服务出现“ SQL Server Reporting Services 帐户是本地用户且不受支持 ”错误的解决方法 安装好C...
  • zhang7583859
  • zhang7583859
  • 2014年08月19日 14:36
  • 2872

SQL Reporting Services配置

最近部署Reporting Services,不是提示“报表服务器没有响应”就是权限问题,后来做了一下步骤部署成功,仅供参考1、默认网站80端口无法开启,因为系统安装oracle,暂用80端口,将所有...
  • bing1051
  • bing1051
  • 2011年05月26日 10:19
  • 554
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:微软SQL Server 2000 Reporting Services介绍(五)
举报原因:
原因补充:

(最多只允许输入30个字)