当前位置:首页 > 网络编程 > WEB编程 > ASP.net >  使用ADO.NET的最佳实践 8

 使用ADO.NET的最佳实践 8

点击次数:31 次 发布日期:2008-11-26 11:18:42 作者:源代码网
源代码网推荐      始终关闭Connection和DataReader
源代码网推荐  
源代码网推荐    完成对Connection或 DataReader对象的使用后,总是显式地关闭它们。尽管垃圾回收最终会清除对象并因此释放连接和其他托管资源,但垃圾回收仅在需要时执行。因此,确保任何宝贵的资源被显式释放仍然是您的责任。并且,没有显式关闭的Connections可能不会返回到池中。例如,一个超出作用范围却没有显式关闭的连接,只有当连接池大小达到最大并且连接仍然有效时,才会被返回到连接池中。
源代码网推荐  
源代码网推荐    注不要在类的Finalize方法中对Connection、DataReader或任何其他托管对象调用Close或Dispose。最后完成的时候,仅释放类自己直接拥有的非托管资源。如果类没有任何非托管资源,就不要在类定义中包含Finalize方法。
源代码网推荐  
源代码网推荐    在C#中使用“Using”语句
源代码网推荐  
源代码网推荐    对于C#程序员来说,确保始终关闭Connection和DataReader对象的一个方便的方法就是使用using语句。using语句在离开自己的作用范围时,会自动调用被“使用”的对象的Dispose。例如:
源代码网推荐  
源代码网推荐  //C#
源代码网推荐  string connString = "Data Source=localhost;Integrated Security=SSPI;Initial Catalog=Northwind;";
源代码网推荐  
源代码网推荐  using (SqlConnection conn = new SqlConnection(connString))
源代码网推荐  {
源代码网推荐  SqlCommand cmd = conn.CreateCommand();
源代码网推荐  cmd.CommandText = "SELECT CustomerId, CompanyName FROM Customers";
源代码网推荐  
源代码网推荐  conn.Open();
源代码网推荐  
源代码网推荐  using (SqlDataReader dr = cmd.ExecuteReader())
源代码网推荐  {
源代码网推荐  while (dr.Read())
源代码网推荐  Console.WriteLine("{0} {1}", dr.GetString(0), dr.GetString(1));
源代码网推荐  }
源代码网推荐  }
源代码网推荐  
源代码网推荐    Using语句不能用于Microsoft Visual Basic .net。
源代码网推荐   
源代码网推荐    避免访问OleDbConnection.State属性
源代码网推荐  
源代码网推荐    如果连接已经打开,OleDbConnection.State属性会对DBPROP_CONNECTIONSTATUS属性的 DATASOURCEINFO属性集执行本地OLE DB调用IDBProperties.GetProperties,这可能会导致对数据源的往返行程。也就是说,检查State属性的代价可能很高。所以仅在需要时检查State属性。如果需要经常检查该属性,监听OleDbConnection的StateChange事件可能会使应用程序的性能好一些。
源代码网推荐  
源代码网推荐    与XML集成
源代码网推荐  
源代码网推荐    ADO.NET在DataSet中提供了广泛的XML集成,并公开了SQL Server 2000及其更高版本提供的部分XML功能。还可以使用SQLXML 3.0广泛地访问SQL Server 2000及其更高版本中的XML功能。下面是使用XML和ADO.NET的技巧和信息。
源代码网推荐  
源代码网推荐    DataSet和XML
源代码网推荐  
源代码网推荐    DataSet与XML紧密集成,并提供如下功能:
源代码网推荐  
源代码网推荐    1) 从XSD架构中加载DataSet的架构或关系型结构。
源代码网推荐  
源代码网推荐    2) 从XML加载DataSet的内容。
源代码网推荐  
源代码网推荐    3) 如果没有提供架构,可以从XML文档的内容推断出DataSet的架构。
源代码网推荐  
源代码网推荐    4) 将DataSet的架构写为XSD架构。
源代码网推荐  
源代码网推荐    5) 将DataSet的内容写为XML。
源代码网推荐  
源代码网推荐    6) 同步访问使用DataSet的数据的关系表示,以及使用XmlDataDocument的数据的层次表示。
源代码网推荐  
源代码网推荐    注可以使用这种同步将XML功能(例如,XPath查询和XSLT转换)应用到DataSet中的数据,或者在保留原始XML保真度的前提下为XML文档中数据的全部或其中一个子集提供关系视图。
源代码网推荐  
源代码网推荐    架构推断
源代码网推荐  
源代码网推荐    从XML文件加载DataSet时,可以从XSD架构加载DataSet架构,或者在加载数据前预定义表和列。如果没有可用的XSD架构,而且不知道为XML文件的内容定义哪些表和列,就可以在XML文档结构的基础上对架构进行推断。
源代码网推荐  
源代码网推荐    架构推断作为迁移工具很有用,但应只限于设计阶段应用程序,这是由于推断处理有如下限制。
源代码网推荐  
源代码网推荐    1) 对架构的推断会引入影响应用程序性能的附加处理。
源代码网推荐  
源代码网推荐    2) 所有推断列的类型都是字符串。
源代码网推荐  
源代码网推荐    3) 推断处理不具有确定性。也就是说,它是基于XML文件内容的,而不是预定的架构。因此,对于两个预定架构相同的XML文件,由于它们的内容不同,结果得到两个完全不同的推断架构。
源代码网推荐  
源代码网推荐    用于XML查询的SQL Server
源代码网推荐  
源代码网推荐    如果正从SQL Server 2000 FOR XML返回查询结果,可以让用于SQL Server的.NET框架数据提供程序使用SqlCommand.ExecuteXmlReader方法直接创建一个XmlReader。
源代码网推荐  
源代码网推荐    SQLXML托管类
源代码网推荐  
源代码网推荐    .NET框架中有一些类,公开用于SQL Server 2000的XML的功能。这些类可在Microsoft.Data.SqlXml命名空间中找到,它们添加了执行XPath查询和XML模板文件以及将XSLT转换应用到数据的能力。
源代码网推荐  
源代码网推荐    SQLXML托管类包含在用于Microsoft SQL Server 2000的XML (SQLXML 2.0)发行版中,可通过链接XML for Microsoft SQL Server 2000 Web Release 2 (SQLXML 2.0)  做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。
源代码网推荐


源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华