当前位置 > 首页 > Asp.net

ASP.NET Web开发框架之三 报表开发

9/20/2012 9:15:00 AM来源:Asp.net

Enterprise Solution Web部分目前只实现了对RDLC的支持。实现一种报表格式的支持,需要做一些基础的工作以便于与系统紧密的集成。

 

绑定数据源

首先看一下,我们在要报表中使用RDLC报表,经过设计报表文件,添加报表控件,然后我们需要增加下面的代码,来绑定数据到报表中,以查看数据。

//绑定报表
reportViewer.LocalReport.ReportPath = MapPath( "SalesReport.rdlc");
//绑定数据源 dataset1必须和你报表所引用的table 一致
reportDataSource rds = new ReportDataSource("SalesOrder", ds.Table[0]);
reportViewer.LocalReport.DataSources.Add(rds);
reportViewer.LocalReport.Refresh();

这个过程,每做一个新报表,都需要用此方法,给报表绑定数据。

Enterprise Solution系统因为知道数据源的位置,因为在数据库注册的地方,有注册所此用的数据库

image

其次,如何取数据呢,再参看报表定义文件中的内容,关键部分如下所示

<DataSet Name="DataSet1">
<Fields>
<Field Name="USERID">
<DataField>USERID</DataField>
<rd:TypeName>System.String</rd:TypeName>
</Field>
<Field Name="USER_NAME">
<DataField>USER_NAME</DataField>
<rd:TypeName>System.String</rd:TypeName>
</Field>
<rd:DataSetInfo>
<rd:TableName>ADUSER</rd:TableName>
...... 

关键点也在此处,借助于Linq to xml,我可以解析成如下的SQL语句

SELECT USERID,USER_NAME FROM ADUSER

把这个结果,用微软企业数据访问库,返回给报表,如下代码所示

foreach (DataTable table in dataset.Tables)
{
DataTable tbl = SqlHelper.ExecuteDataset(connectionString, CommandType.Text, sqls [table.TableName]).Tables[0];

foreach (DataRow oRow in tbl.Rows)
table.ImportRow(oRow);
}

就达到了,报表自动取值的目的。这是通用的方法,可以简化大量的C#报表编码工作,像此段落开头的那段代码,现在完全可以省略。

 

多语言配置

其次,报表界面中的标签,一般为静态的标签,无法与软件系统的界面相匹配,造成打印出来的报表,报表语言可能与用户的偏号不一致。到目前为止,我了解到的两种方案,一各是,在界面要用到文本标签的地方,引用外部的资源字符串,再根据程序的Culture来返回不同的字符串资源,关键的设置点是引用外部字符串资源程序集

image

如果您想了解更多,可参考关键字"Using Custom .NET Code with Reports”找到更多相关内容。

第二种方法,也是我到更为合理的办法。报表定义文件本身是XML格式的,在报表呈现之前,可以把报表中的标签文本,替换成适当的字符串语言资源。关键部分的代码,看起来是这样的

TextReader rdl=null;
using(FileSt

  • 设计模式一 - Simple Factory, Factory Method, Abstract Factory以及Builder模式简述

    2/2/2010 7:22:00 AM

    阅读: 662 评论: 3 作者: 流云之心 发表于 2010-02-01 13:25 原文链接 虽然现在博客园上关于设计模式的文章已经有很多,但还是写一篇来凑下热闹,也算是对自己多这几种

  • 搜索引擎下,中文域名何去何从

    4/18/2009 12:44:00 AM

    摘要: 不知道从什么时候开始,大家开始讨论中文域名了。于是,我上网查了一下,得到如下信息:中文域名以中文作为域名的组成部分,以实现在地址栏内输入中文达到访问网站的目的。信息产业部规定,我国合法的中文

  • Open DotNetNuke Position with MarketGraphics Group

    7/16/2011 2:41:00 AM

    I received an email earlier this week from a company called the MarketGraphics Research Group. They

  • EndCoding 代码生成工具

    12/26/2009 10:35:00 AM

    阅读: 4 评论: 0 作者: 新瓶老酒 发表于 2009-12-26 10:14 原文链接 EndCoding 代码生成工具(演示教程) EndCoding 代码生成工具演示视频下

  • 也谈接口和抽象类区别

    5/21/2007 3:47:00 PM

    好象这是一个老生常谈的问题,最近有个学生问我他们的区别,于是我就又想起这个话题。 有不少的文章在描述这两者,但好象都没有怎么从初学者的浅显角度来看。 其实这两者有很多相识之处,当然也有很多不同之

  • 一种简单的数据库分流的算法及实现

    8/17/2007 8:35:00 AM

    摘要: 如何将一个大型数据库分散成几个小型的库,一方面加快查询速度,另一方面能够将数据库服务分散到几个不同的服务器上从而增强系统的反映能力 阅读全文 黄金年代 2007-08-16 20

  • 在写SharePoint查询XML字符串的时候要注意的一个问题

    5/14/2007 1:55:00 AM

    偶然在SharePointBlogs组里面看到的。 来源: MdPs MOSS Blog <And>和<Or>标签里面是不能同时套3个或更多比较标签的。 举例:

  • delphi中操作Excel用分列方法将数字转换为文本格式

    4/25/2009 4:05:00 PM

    Excel中有一列数据是数字和文本方式混合排列的,在用ADO导入数据时就会出现部分数据不能导入的问题 解决这个问题 首先想到的是常用的数字转换为文本格式的方法 WorkSheet.Column

  • 一些MCMS小结

    6/28/2007 2:32:00 PM

    摘要: 好久没有写BLOG了,放上近段时间在下在学习/维护MCMS中的一些小结供大家分享,有不正确的地方或是更好的解决方案也请大家指出 阅读全文 极地银狐.NET 2007-06-28

  • 什么是依赖注入?(听来的一个笑话)

    6/13/2009 2:58:00 AM

    首先,马桶是一个大大的容器,能够容纳各种秽物。而且您应该明确这个观点:这个技术的根本目的就是让您和您拉的屎能够轻松的进行分离,不至于在您排泄的过程中拉的满裤子都是而无法清理,否则您就得通过其他手段,