当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > ASP.NET 2.0中DataTable小兵变大将

ASP.NET
ASP.NET超凡的代码控制(二)
剖析ASP.NET下部构造(一)
剖析ASP.NET下部构造(二)
ASP.NET的Web controls(一)
ASP.NET的Web controls(二)
如何在页面上动态的生成 WebForm控件
再议正则表达式(这次是在asp.net 上的应用)
利用.NET框架简化发布和解决DLL Hell问题(1)
利用.NET框架简化发布和解决DLL Hell问题(2)
在ASP+中访问数据库
通过事例学习.net的WebForms技术(一)
通过事例学习.net的WebForms技术(二)
如何在aspx中得到在存储过程中的的数值(兼答jspfuns的问题)
如何得到一个汉字和字母组合的字符串的准确的长度(asp.net 版本的)
ASP+中取代ASP的RS(Remote Scripting)技术的Framework
通过事例学习.net的WebForms技术(三)
通过事例学习.net的WebForms技术(四)
通过事例学习.net的WebForms技术(五)
通过网络域名得到这台主机的IP地址
查看服务器磁盘、文件的aspx

ASP.NET 2.0中DataTable小兵变大将


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 181 ::
收藏到网摘: n/a

作者:蝈蝈俊出处:博客堂

我们先看一段WEBService的代码。

[WebMethod]
publicDataTableGetInfo()
...{
OleDbConnectionnwindConn=newOleDbConnection(
"Provider=Microsoft.Jet.OLEDB.4.0;"+
"DataSource=D:\\Northwind\\northwind.mdb;");

OleDbCommandselectCMD=
newOleDbCommand("SELECTCustomerID,CompanyNameFROMCustomers"
,nwindConn);
selectCMD.CommandTimeout=30;

OleDbDataAdaptercustDA=newOleDbDataAdapter();
custDA.SelectCommand=selectCMD;

DataSetcustDS=newDataSet();
custDA.Fill(custDS,"Customers");
returncustDS.Tables[0];
}

在.net1.1中,这是典型的一个错误,在.net1.1、1.0中,WEBService的返回或者输入参数不能是DataTable,这是一个众人皆知的知识点。原因就是DataTable不象DataSet那样支持序列化。在.net1.1中,我们解决这个问题的方法就是使用DataSet。但是使用DataSet的时候,经常会有一种杀鸡用牛刀的感觉。

附:.net1.1中使用DataTable作为WEBService返回值会报以下异常:

类型System.ComponentModel.ISite的成员System.ComponentModel.MarshalByValueComponent.Site是接口,因此无法将其序列化。

在.net2.0中,以上同样的代码,则没有任何问题了。原因是2.0中DataTable实现了序列化、反序列。

在VS2005Beta2的文档中,我们可以看到2.0中DataTable实现了以下接口:

ExplicitInterfaceImplementations
System.ComponentModel.IListSource.get_ContainsListCollection
System.ComponentModel.IListSource.GetList
System.Xml.Serialization.IXmlSerializable.GetSchema
System.Xml.Serialization.IXmlSerializable.ReadXml
System.Xml.Serialization.IXmlSerializable.WriteXml

而在1.1中,DataTable只实现了一个接口:

ExplicitInterfaceImplementations
System.ComponentModel.IListSource.ContainsListCollection

把DataSet中的一些功能移到DataTable中,2.0中还有Merge方法,即合并数个数据集。

DataTable的代码合并参看下面代码。

privatestaticvoidDemonstrateMergeTable()
...{
DataTabletable1=newDataTable("Items");

DataColumncolumn1=newDataColumn("id",typeof(System.Int32));
DataColumncolumn2=newDataColumn("item",typeof(System.Int32));
table1.Columns.Add(column1);
table1.Columns.Add(column2);

table1.PrimaryKey=newDataColumn[]...{column1};
table1.RowChanged+=newSystem.Data.DataRowChangeEventHandler(Row_Changed);

DataRowrow;
for(inti=0;i<=3;i++)
...{
row=table1.NewRow();
row["id"]=i;
row["item"]=i;
table1.Rows.Add(row);
}

//Acceptchanges.
table1.AcceptChanges();

DataTabletable2=table1.Clone();
row=table2.NewRow();
row["id"]=14;
row["item"]=774;
table2.Rows.Add(row);

row=table2.NewRow();
row["id"]=12;
row["item"]=555;
table2.Rows.Add(row);

row=table2.NewRow();
row["id"]=13;
row["item"]=665;
table2.Rows.Add(row);

//Mergetable2intothetable1.
table1.Merge(table2);
}

综合上述,.net2.0中DataTable从后台的默默无问的小兵变成独当一面的大将了。