微软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文件来实现功能,能节约大量的时间。
上一篇:微软SQL Server 2000 Reporting Services介绍(四)
下一篇:Microsoft SQL Server 2005 的 XML 最佳实施策略
|