欢迎光临
我们一直在努力

微软SQL Server 2000 Reporting Services介绍(五)-.NET教程,算法/线程

建站超值云服务器,限时71元/月

微软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中进行预览.

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 微软SQL Server 2000 Reporting Services介绍(五)-.NET教程,算法/线程
分享到: 更多 (0)