问个简单的常识性的问题
vs2005中ado.net和vs2003中的ado.net相比,变化大吗,ado.net是.netframework自带的吗 谢谢 问题点数:20、回复次数:5Top
1 楼Eddie005(♂) №.零零伍 (♂)回复于 2006-06-02 15:59:37 得分 0
http://community.csdn.net/Expert/topic/4695/4695603.xml?temp=.9980127Top
2 楼Eddie005(♂) №.零零伍 (♂)回复于 2006-06-02 16:01:36 得分 20
①模型的调整:
例如在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
Top
3 楼szc21(卖炭翁)回复于 2006-06-02 16:03:04 得分 0
到现在还没装05,郁闷Top
4 楼sbsrg3000(⊙⌒⊙怪事,这几天可用分又没增加....)回复于 2006-06-02 16:05:14 得分 0
03成成精后再05....markTop
5 楼yd(达子)回复于 2006-06-02 16:26:45 得分 0
05的资料不多,尤其是书。
1、ado.net 在VS03 和 05 使用方法差别不大
2、ado.net是.netframework自带的,并且是架构的重要革新Top




