国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

ASP.NET Web開發(fā)框架之三 報表開發(fā)

開發(fā) 后端
Enterprise Solution Web部分目前只實現(xiàn)了對RDLC的支持。實現(xiàn)一種報表格式的支持,需要做一些基礎(chǔ)的工作以便于與系統(tǒng)緊密的集成。

Enterprise Solution Web部分目前只實現(xiàn)了對RDLC的支持。實現(xiàn)一種報表格式的支持,需要做一些基礎(chǔ)的工作以便于與系統(tǒng)緊密的集成。

綁定數(shù)據(jù)源

首先看一下,我們在要報表中使用RDLC報表,經(jīng)過設(shè)計報表文件,添加報表控件,然后我們需要增加下面的代碼,來綁定數(shù)據(jù)到報表中,以查看數(shù)據(jù)。

  1. //綁定報表  
  2. reportViewer.LocalReport.ReportPath = MapPath( "SalesReport.rdlc");              
  3. //綁定數(shù)據(jù)源  dataset1必須和你報表所引用的table 一致  
  4. reportDataSource rds = new ReportDataSource("SalesOrder", ds.Table[0]);  
  5. reportViewer.LocalReport.DataSources.Add(rds);  
  6. reportViewer.LocalReport.Refresh(); 

這個過程,每做一個新報表,都需要用此方法,給報表綁定數(shù)據(jù)。

Enterprise Solution系統(tǒng)因為知道數(shù)據(jù)源的位置,因為在數(shù)據(jù)庫注冊的地方,有注冊所此用的數(shù)據(jù)庫

image

其次,如何取數(shù)據(jù)呢,再參看報表定義文件中的內(nèi)容,關(guān)鍵部分如下所示

  1.  <DataSet Name="DataSet1">  
  2.       <Fields>  
  3.         <Field Name="USERID">  
  4.           <DataField>USERID</DataField>  
  5.           <rd:TypeName>System.String</rd:TypeName>  
  6.         </Field>  
  7.         <Field Name="USER_NAME">  
  8.           <DataField>USER_NAME</DataField>  
  9.           <rd:TypeName>System.String</rd:TypeName>  
  10.         </Field>  
  11.  <rd:DataSetInfo>     
  12.         <rd:TableName>ADUSER</rd:TableName>  
  13. ...... 

關(guān)鍵點也在此處,借助于Linq to xml,我可以解析成如下的SQL語句

  1. SELECT USERID,USER_NAME FROM ADUSER 

把這個結(jié)果,用微軟企業(yè)數(shù)據(jù)訪問庫,返回給報表,如下代碼所示

  1. foreach (DataTable table in dataset.Tables)  
  2. {  
  3.      DataTable tbl = SqlHelper.ExecuteDataset(connectionString, CommandType.Text, sqls  [table.TableName]).Tables[0];  
  4.  
  5.        foreach (DataRow oRow in tbl.Rows)  
  6.                 table.ImportRow(oRow);  

就達到了,報表自動取值的目的。這是通用的方法,可以簡化大量的C#報表編碼工作,像此段落開頭的那段代碼,現(xiàn)在完全可以省略。 

多語言配置

其次,報表界面中的標(biāo)簽,一般為靜態(tài)的標(biāo)簽,無法與軟件系統(tǒng)的界面相匹配,造成打印出來的報表,報表語言可能與用戶的偏號不一致。到目前為止,我了解到的兩種方案,一各是,在界面要用到文本標(biāo)簽的地方,引用外部的資源字符串,再根據(jù)程序的Culture來返回不同的字符串資源,關(guān)鍵的設(shè)置點是引用外部字符串資源程序集

image

如果您想了解更多,可參考關(guān)鍵字"Using Custom .NET Code with Reports”找到更多相關(guān)內(nèi)容。

第二種方法,也是我到更為合理的辦法。報表定義文件本身是XML格式的,在報表呈現(xiàn)之前,可以把報表中的標(biāo)簽文本,替換成適當(dāng)?shù)淖址Z言資源。關(guān)鍵部分的代碼,看起來是這樣的

  1. TextReader  rdl=null;  
  2. using(FileStream fileStream = File.OpenRead(path))  
  3. {  
  4. MemoryStream memStream = new MemoryStream();  
  5. memStream.SetLength(fileStream.Length);  
  6. fileStream.Read(memStream.GetBuffer(), 0, (int)fileStream.Length);  
  7.               
  8. //多國語言處理   2表示簡體中文  
  9. Foundation.Common.LanguageTranslator.LanguageCode = 2;  
  10. rdl = ReportRenderHelper.Localize(fileStream);  
  11. }  
  12. reportViewer.LocalReport.LoadReportDefinition(rdl);  
  13. reportViewer.LocalReport.Refresh(); 

因為RDLC/RDL報表支持從一個TextReader中加載報表,不一定非要從硬盤報表文件中加載報表,在此,可以做相關(guān)的語言轉(zhuǎn)化工作。

多版本支持

第三,不管是哪種類型的報表,發(fā)展到到目前為止,均出現(xiàn)了多種不同的版本。客戶的服務(wù)器也可能會是不同版本的Server系統(tǒng)。微軟的組件兼容性好,但同時,也有很霸道的地方。比如,Visual Studio 2012明確只支持Windows 7及以上的OS,SQL Server 2012不再支持SQL Server 2000格式的數(shù)據(jù)庫。對于這里要用到的ReportViewer控件,對于SQL Server 2012,并沒有出對應(yīng)的新版本的控件,所以,如果要瀏覽Report Builder 3 for SQL Server 2012設(shè)計出來的RDLC報表,呈現(xiàn)此報表的控件,仍然是SQL Server 2008版本的組件,如下版本所示

  1. <%@ Register Assembly="Microsoft.ReportViewer.WebForms, Version=10.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"   
  2.     Namespace="Microsoft.Reporting.WebForms" TagPrefix="rsweb" %>   

再以Crystal Report為例子,它的runtime就有好多個版本,同一個版本又有x86和x64的區(qū)別

image

最新版本的是for visual studio 2010, 主版本號13。這么多runtime要能同時支持,只有用反射,根據(jù)客戶端安裝的版本,來創(chuàng)建不同版本的runtime對象。或是以簡單的方法,規(guī)定要用指定版本的runtime,其它的則不支持。

例子代碼如下所示,可供您參考實現(xiàn)

  1. Assembly engineAssembly = Assembly.Load(GetLongAssemblyName("CrystalDecisions.CrystalReports.Engine", version));  
  2. Assembly sharedAssembly = Assembly.Load(GetLongAssemblyName("CrystalDecisions.Shared", version));  
  3. Type printingConverterType = engineAssembly.GetType("CrystalDecisions.CrystalReports.Engine.PrintingConverter");  

動態(tài)參數(shù)支持

RDLC不支持parameter,RDL才支持。微軟對此的解釋是,RDLC在取數(shù)時,要進行參數(shù)化處理,取出來的數(shù)據(jù),是經(jīng)過參數(shù)過濾的。RDL支持參數(shù),傳遞參數(shù)時,使用像這樣的代碼片段

  1. ReportParameter[] parm = new ReportParameter[1];  
  2. parm[0] = new ReportParameter("deptno", txtDeptno.Text);  
  3. reportViewer.ShowCredentialPrompts = false;  
  4. reportViewer.ProcessingMode = Microsoft.Reporting.WebForms.ProcessingMode.Remote;  
  5. reportViewer.ServerReport.ReportServerUrl = new System.Uri("http://localhost/ReportServer");  
  6. reportViewer.ServerReport.ReportPath = "/EnterpriseSolution/SalesOrder";  
  7. reportViewer.ServerReport.SetParameters(parm);  
  8. reportViewer.ServerReport.Refresh(); 

參數(shù)處理的奧妙,如下圖所示,在報表對話框中設(shè)計參數(shù),運行時會動態(tài)創(chuàng)建控件,供用戶輸入值,再由運行時,將此值傳遞到報表中,達到簡化編碼的目的,經(jīng)過這樣處理,同樣,不需要編寫任何C#代碼而達到傳遞參數(shù)值的目的

image

字段格式,是最終要傳化為參數(shù)的格式,數(shù)據(jù)類型表示控件要使用的樣式。對于類型轉(zhuǎn)化,微軟提供了這樣的方法

  1. object obj = ReflectionHelper.GetPropertyValue(control, targetProperty);  
  2. object converted = Convert.ChangeType(obj, type);  
  3. ReflectionHelper.SetPropertyValue(entity, arr[1], converted); 

用文字來描述這段代碼的含義。以TextBox為例子,第一句取到TextBox的Text屬性,它是個字符串,如果type要求是的數(shù)字,則第二句把它轉(zhuǎn)化為字符串,第三句則應(yīng)用反射將值傳遞給報表對象。在Visual Studio調(diào)試時,字符串有雙引號,數(shù)字則沒有,雖然看起來它們都是object,值也很相似,但屬于不同類型,在運算時如果沒有轉(zhuǎn)化,會出錯。

 

原文鏈接:http://www.cnblogs.com/JamesLi2015/archive/2012/09/20/2694669.html

責(zé)任編輯:張偉 來源: James Li的博客
相關(guān)推薦

2012-09-18 11:02:10

ASP.NETC#Web Forms

2012-09-25 09:31:58

ASP.NETC#Web

2012-10-08 14:01:54

ASP.NETWebC

2012-09-18 14:32:08

ASP.NETC#

2012-09-26 09:46:29

ASP.NETWeb框架

2009-07-29 09:38:06

Web開發(fā)ASP.NET

2012-09-19 14:10:58

ASP.NETWebC

2014-06-30 09:22:38

ASP.NETBootstrap

2009-07-24 10:14:22

ASP.NET開發(fā)

2009-04-20 13:34:27

ASP.NET視頻教程Web開發(fā)

2012-09-29 13:20:30

ASP.NETWeb框架

2009-08-05 10:36:08

開發(fā)ASP.NET

2009-08-04 10:43:59

ASP.NET控件開發(fā)

2009-07-27 16:19:59

ASP.NET報表控件

2009-08-13 09:01:00

ASP.NET開發(fā)Web標(biāo)準(zhǔn)

2009-08-03 15:53:11

ASP.NET移動開發(fā)

2009-08-03 13:30:47

ASP.NET開發(fā)

2009-08-07 15:24:16

ASP.NET模板控件

2009-08-04 16:33:50

ASP.NET移動開發(fā)

2009-08-10 18:24:29

ASP.NET開發(fā)環(huán)境
點贊
收藏

51CTO技術(shù)棧公眾號

97精品国产| 久久伊人色综合| 激情视频一区二区| 九九视频精品免费| 国产91视频一区| 久久这里都是精品| 又黄又爽在线免费观看| 欧美午夜女人视频在线| 国产精品第一国产精品| 国产精品国产精品| 国产精品久久久一本精品| caopon在线免费视频| 中文字幕亚洲欧美日韩在线不卡| 超碰在线一区| 亚洲国产欧美不卡在线观看 | 国产 国语对白 露脸| 日本欧美黄色片| 欧美日韩精品不卡| 欧美视频久久| 久久99精品久久久久久久久久| 亚州综合一区| 欧美中文娱乐网| 国产精品久久久久久久午夜片 | 欧美午夜三级| 欧美一级视频免费在线观看| 综合久久十次| 99.玖玖.com| 一本一本久久a久久精品牛牛影视 一本色道久久综合亚洲精品小说 一本色道久久综合狠狠躁篇怎么玩 | 色狠狠桃花综合| 欧美片第1页| 麻豆亚洲一区| 最新日韩av在线| 美洲精品一卡2卡三卡4卡四卡| 97精品视频在线| 国产精品综合在线视频| caoporn国产精品免费视频| 欧美成人亚洲成人| 秋霞午夜鲁丝一区二区老狼| 米奇精品一区二区三区| 成人日韩在线电影| 欧美理论在线观看| 久久综合网hezyo| 国产乱人伦偷精品视频免下载 | 欧美日韩国产高清一区二区| 九九视频精品全部免费播放| 日韩手机在线观看视频| 一本色道久久综合狠狠躁篇的优点| 中文字幕一区二区三区欧美日韩| 波多野结衣xxxx| 欧美乱妇高清无乱码| 极品少妇xxxx精品少妇| 巨大荫蒂视频欧美大片| 国产不卡av在线| 亚洲一区二区免费视频| av自拍一区| 免费男女羞羞的视频网站中文版| 中文字幕欧美日韩| 不卡一区在线观看| 亚洲18在线| 91亚洲免费视频| 国外成人免费在线播放 | 一级二级在线观看| 国产成+人+综合+亚洲欧洲| 亚洲成av人片一区二区三区| 91久久国产| 黄色免费在线观看| 欧美日韩一区二区三区电影| 亚洲人成五月天| 2024国产精品视频| 色135综合网| 日韩三级免费| 日韩伦理在线免费观看| 久久久久久久网站| 欧洲人成人精品| av午夜精品一区二区三区| 欧美久久综合网| a级片在线免费| 美女av电影| 日韩欧美国产二区| 久久久久久久久久婷婷| 欧美日韩一区二区三区四区五区| 国产激情视频一区二区三区欧美| 在线视频亚洲专区| 中文字幕高清在线播放| 天堂8在线天堂资源bt| 久久精品夜夜夜夜夜久久| 中文一区在线播放 | 美女扒开大腿让男人桶| 亚洲人成啪啪网站| 福利视频第一区| 成人动漫精品一区二区| 中文精品电影| 在这里有精品| 欧美激情黑人| 国产一区高清视频| 日本在线观看a| 久久久久99精品一区| 亚洲性猛交xxxxwww| 黄色羞羞视频在线观看| 久久精品日产第一区二区三区精品版| 日韩一级高清毛片| 18欧美亚洲精品| 国产电影一区二区三区| 一本一本久久a久久综合精品| 嫩草伊人久久精品少妇av杨幂| 黄色直播在线| 国产九九九九九| 91丝袜脚交足在线播放| 不卡av在线播放| 亚洲精品视频免费| 婷婷综合在线观看| 久久色在线视频| 丁香一区二区三区| 日韩国产在线观看| 国产精品magnet| 婷婷精品进入| 久久高清精品| 超碰成人在线观看| 网曝91综合精品门事件在线| 国产精品17p| 欧美男男freegayvideosroom| 国产97在线 | 亚洲| 国产精品黄色影片导航在线观看| 国产精品伦一区二区三级视频| 精品国产乱码久久久久久果冻传媒| 日本不卡在线| 亚洲色图16p| 成年女人18级毛片毛片免费| 国产精品久久久久999| 亚洲免费福利视频| 91精品国产91久久综合桃花| 伊人色综合久久天天人手人婷| 亚洲综合激情| 日韩大片在线免费观看| 高清av一区二区三区| 色呦呦在线播放| 日本男女交配视频| 欧美激情精品在线| 亚洲天堂av综合网| 欧美精品免费视频| 欧美日韩免费看| 亚洲高清久久久| 黑人一区二区| 日韩激情电影| 先锋欧美三级| 精品三级国产| 日本高清中文字幕二区在线| 日本欧美视频在线观看| 精品久久sese| 国产精品久久999| 日日骚久久av| 欧美刺激午夜性久久久久久久| 国产精品情趣视频| 国产福利一区二区| 豆国产96在线|亚洲| 久久男女视频| 亚洲欧洲视频| 欧美视频亚洲视频| 日韩在线欧美| 女同久久另类99精品国产| www免费网站在线观看| 欧美综合在线播放| 51国产成人精品午夜福中文下载| 2019中文字幕免费视频| 亚洲女在线观看| 欧美日韩午夜精品| 日韩av在线免播放器| 亚洲超丰满肉感bbw| 久久成人免费网| 网友自拍区视频精品| 午夜激情在线观看| 日韩av资源在线| 国内精品久久久久国产| 91国内外精品自在线播放| 黄动漫在线免费观看| 日韩精品一二| 李宗瑞系列合集久久| 三上悠亚av一区二区三区| 97国产精东麻豆人妻电影| 国产911在线观看| 无码精品国产一区二区三区免费| 黄页免费在线观看| 欧美巨大丰满猛性社交| 日韩激情啪啪| 不卡视频一二三四| 亚洲精品av在线| 福利视频久久| 天堂资源在线亚洲资源| 久久精品日韩| 黄色污污在线观看| 精品人妻大屁股白浆无码| 日韩欧美亚洲在线| 亚洲免费在线精品一区| 国产一二三四五| 91亚洲免费视频| 成人性生交大片免费看96| 欧美精品国产一区| 天天综合网天天做天天受| 91精品国产高清久久久久久久久| 69久久夜色精品国产7777|