体验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,上面这些东西就没有试过,简单提一下,留给别人讲~~

ADO.NET 2.0编程

http://docs.google.com/Doc?id=dqsbw4c_59fqd2tgcd
  • sheismylife
  • sheismylife
  • 2008年03月01日 18:18
  • 2353

ADO.NET2.0技术内幕/微软技术丛书(奋斗的小鸟)_PDF 电子书

下载地址:
  • tjoy2005
  • tjoy2005
  • 2013年10月09日 14:01
  • 992

《C#2.0锐利体验系列课程》第一讲——泛型

一个简单的泛型示例:定义:class Stack {        private T[] store;        private int size;        public Stack() ...
  • yanghua_kobe
  • yanghua_kobe
  • 2010年02月11日 22:08
  • 1113

ADO.NET 2.0技术内幕_连接池

3.6  连  接  池与微软以前的数据访问技术类似,ADO.NET包括对连接池的内置支持。3.6.1  连接句柄和物理连接如果正在使用Visual Studio,可以使用Visual Studio调...
  • tuwen
  • tuwen
  • 2008年05月28日 20:45
  • 1130

用ADO.Net实现Oracle大批量数据更新优化处理方法

序言在业务系统应用中,经常会使用到大量数据的的提交(包括查询、更新或删除),如果目标数据库的数据量较大,一次需要处理的操作较多,就会出现系统执行效率低下等问题。文本以Oracle9i数据库为例,通过对...
  • lbluekey
  • lbluekey
  • 2008年01月16日 12:11
  • 917

跟着老桂学ASP.NET Core 2.0

.net core作为微软开发技术中跨平台的利器,2.0的发布已经有一段时间了,asp.net core是新一代微软的BS开发框架,同时兼容.net core和.net framework,它的出现,...
  • sD7O95O
  • sD7O95O
  • 2017年11月24日 00:00
  • 420

Ado.net 2.0学习

所谓ADO.NET是一组用于和数据源进行交互的面向对象类库,就是访问数据库SQL Access 或XML Excel等数据源而已。访问数据首先就要建立到操作对象的连接,这就是connection对象,...
  • redrainy
  • redrainy
  • 2007年04月23日 15:41
  • 542

ADO.NET之Parameter属性

在ADO.NET中, public SqlParameterCollection Parameters {get;}会得到一个SqlParameter属性。下面通过一个例子进行详细的认识吧。//例如...
  • Marksinoberg
  • Marksinoberg
  • 2015年12月18日 20:40
  • 7710

用了ADO.NET 2.0 SQ

用了ADO.NET 2.0 SQLite Data Provider 这样可以直接利用它来创建一个加密的sqlite数据库。 有关c#代码如下: 1、创建空的sqlite数据库。 //数据库名...
  • zhangtaoxgu
  • zhangtaoxgu
  • 2012年07月03日 21:24
  • 378

ADO.NET 2.0 功能一览

ADO.NET 2.0 功能一览 作者:Bob Beauchemin(DevelopMentor)相关技术:ADO.NET 2.0、SQL Server 2005难度:★★★☆☆读者类型:.NET开发...
  • SafeF8
  • SafeF8
  • 2005年06月26日 17:49
  • 1659
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:体验ado.net 2.0
举报原因:
原因补充:

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