CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  .NET技术 >  ASP.NET

问个简单的常识性的问题

楼主TFulture()2006-06-02 15:55:39 在 .NET技术 / ASP.NET 提问

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

相关问题

关键词

得分解答快速导航

  • 帖主:TFulture
  • Eddie005

相关链接

  • CSDN .NET频道
  • .NET类图书
  • C#类图书
  • .NET类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo