微软SQL Server 2000 Reporting Services介绍(五) - 中国WEB开发者网络 (http://www.webasp.net) -- 技术教程 (http://www.webasp.net/article/) --- 微软SQL Server 2000 Reporting Services介绍(五) (http://www.webasp.net/article/9/8186.htm) |
| -- 作者:未知 -- 发布日期: 2004-03-10 |
| 微软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中进行预览. |
| webasp.net |