体验ado.net 2.0

原创 2006年05月18日 12:00:00

也是简单列些要点和个人体会而已,给还没接触过2.0的兄弟们开个头~

①模型的调整:

例如在ado.net1.0里,SqlConnection、OleDbConnection等,并没有一个共同的基类,而是通过继承接口 IDbConnection实现的,现在,则有了一个基类DbConnection,这可方便了一些,我们可针对基类编写数据库访问的代码,而不用关注具体的数据库类型,有利于数据访问层与数据库的分离~

②关于DataSet(DataTable)的优化:

首先是新的索引引擎,看看例子:
DataTable dt = new DataTable();
dt.Columns.Add("field1");
dt.Columns.Add("field2");
dt.PrimaryKey = new DataColumn[] { dt.Columns[0] };//这句是关键,否则验证不了
for (int i = 0; i < 200000; i++)
     dt.Rows.Add(new object[] { i, DateTime.Now });

上面这段代码在.net1.1执行需要40~50秒; 在.net2.0中运行在10秒左右.

其次是真正的二进制序列化;

将上面这个包含有20万条记录的DataTable序列化成文件:

dt.RemotingFormat = SerializationFormat.Binary;//这个在.net1.1是没有的
System.Runtime.Serialization.Formatters.Binary.BinaryFormatter bf = new System.Runtime.Serialization.Formatters.Binary.BinaryFormatter();
System.IO.FileStream fs = new System.IO.FileStream(@"D:/test1.txt", System.IO.FileMode.CreateNew);
bf.Serialize(fs, dt);
fs.Close();

.net1.1得到的是一个大小约29M的文件;.net2.0得到的是约7M的文件;用记事本打开看看就知道差别在哪里。
在使用Remoting传送DataSet或者DataTable对象的时候,这是一件好事。


最后,在ado.net2.0中,DataTable更独立了,不像过去那样特别依赖DataSet,有时候不得不把DataTable放到DataSet中仅仅是为了获得某项功能,例如ReadXML()、 WriteXMlSchema()等。


③针对MS SQL Server,特别是MS SQL Server2005所作的一些优化:
这有几方面话题,一是异步处理
System.Data.SqlClient.SqlCommand cm = new SqlCommand("async=true;.....");
System.IAsyncResult ar = cm.BeginExecuteReader();
//.....
//do other processing
System.Data.SqlClient.SqlDataReader dr = cm.EndExecuteReader(ar);


二是大批量数据操作的优化
System.Data.SqlClient.SqlBulkCopy bcp = new SqlBulkCopy("连接字符串");
bcp.WriteToServer(myDataTable);

三是在ADO.NET 2.0针对Sql Server 2005可以同时在Command对象上打开多个DataReader


偶的电脑上没有Sql Server 2005,上面这些东西就没有试过,简单提一下,留给别人讲~~

Transaction in ADO.net 2.0

在谈具体实现前 先介绍一下三种事务: 1. 单对象单资源 2. 多对象单资源 3. 多对象多资源(分布式事务, 使用两段提交协议) 在ADO.Net1.0下有两种使用Tra...

Wrox - Professional ADO.NET 2.0

  • 2007年07月01日 16:19
  • 4.54MB
  • 下载

The DataSet Grows Up in ADO.NET 2.0

  • 2007年06月30日 12:07
  • 44KB
  • 下载

3-ADO.NET2.0的十大新特性

ADO.NET2.0的十大新特性     这篇文章概述了.NET Framework 2.0里的ADO.NET2.0的最新特性。在以下叙述中将附带一些简单的例子来讨论这些特性的细节。   以下便...

数据访问技术—ADO.NET 2.0

  • 2009年12月04日 09:53
  • 91KB
  • 下载

Pro ADO.NET 2.0 (2005).

  • 2008年07月27日 23:24
  • 8.62MB
  • 下载

LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL

1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable 可返回类型化为泛型 IEnumerable 的参数。在此示例中,LINQ to SQL(使用...

MSDN ADO.NET 2.0 系列课程1

  • 2009年01月05日 00:22
  • 6.57MB
  • 下载

LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL

运算符转换 1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable 可返回类型化为泛型 IEnumerable 的参数。在此示例中,LINQ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:体验ado.net 2.0
举报原因:
原因补充:

(最多只允许输入30个字)