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

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(FileStream fileStream = File.OpenRead(path)) { MemoryStream memStream = new MemoryStream(); memStream.SetLength(fileStream.Length); fileStream.Read(memStream.GetBuffer(), 0, (int)fileStream.Length); //多国语言处理 2表示简体中文 Foundation.Common.LanguageTranslator.LanguageCode = 2; rdl = ReportRenderHelper.Localize(fileStream); } reportViewer.LocalReport.LoadReportDefinition(rdl); reportViewer.LocalReport.Refresh(); 因为RDLC/RDL报表支持从一个TextReader中加载报表,不一定非要从硬盘报表文件中加载报表,在此,可以做相关的语言转化工作。 多版本支持

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zgffsp.html