萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> ADO.NET實用經驗介紹

ADO.NET實用經驗介紹

   ADO.NET作為微軟最新的數據訪問技術,已經在企業開發中得到了廣泛的應用。對於一線的開發人員來說,掌握基本的概念和技術之後,提高應用水平和解決實際問題的最有效手段,莫過於相互交流彼此的最佳時間經驗經驗。在這篇文章中,兩位ADO.NET專家向讀者毫無保留地、詳盡地介紹了很多實用經驗。

  簡介

  本文為您提供了在Microsoft ADO.NET應用程序中實現和獲得最佳性能、可伸縮性以及功能的最佳解決方案;同時也講述了使用ADO.NET中可用對象的最佳實踐;並提出一些有助於優化ADO.NET應用程序設計的建議。

  .NET框架數據提供程序

  .NET框架中的數據提供程序(Data PRovider)在應用程序和數據源之間起到橋梁作用。.NET框架數據提供程序能夠從數據源中返回查詢結果、對數據源執行命令、將DataSet中的更改傳播給數據源。本文包括有關哪個.NET框架數據提供程序是最適合您需要的一些技巧。

  使用哪個.NET框架數據提供程序?

  為了使您的應用程序獲得最佳性能,請使用最適合您的數據源的.NET框架數據提供程序。有許多數據提供程序可供您的應用程序選用。

  連接到SQL Server 7.0或更高版本

  為了在連接到Microsoft SQL Server 7.0或更高版本時獲得最佳性能,請使用SQL Server .NET數據提供程序。SQL Server .NET數據提供程序的設計目的就在於不通過任何附加技術層就可以直接訪問SQL Server。

  連接到ODBC數據源

  ODBC .NET數據提供程序可在Microsoft.Data.ODBC命名空間中找到,它的體系結構與用於SQL Server和OLE DB的.NET數據提供程序相同。ODBC .NET數據提供程序遵循命名約定-以“ODBC”為前綴(例如,OdbcConnection),並使用標准ODBC連接字符串。

  使用DataReader、DataSet、DataAdapter和DataView

  ADO.NET提供以下兩個對象,用於檢索關系數據並將其存儲在內存中:DataSet和DataReader。DataSet提供一個內存中數據的關系表示形式,一整套包括一些表在內的數據(這些表包含數據、對數據進行排序並約束數據),以及表之間的關系。DataReader提供一個來自數據庫的快速、僅向前、只讀數據流。

  當使用DataSet時,經常會利用DataAdapter(也可能是CommandBuilder)與數據源進行交互。當使用DataSet時,也可以利用DataView對DataSet中的數據應用排序和篩選。也可以從DataSet繼承,創建強類型DataSet,用於將表、行和列作為強類型對象屬性公開。

  下列主題包括的信息涉及:使用DataSet或DataReader的最佳時機、如何優化訪問它們所包含數據、以及如何優化使用DataAdapter(包括CommandBuilder)和DataView的技巧。

  DataSet與DataReader

  當設計應用程序時,要考慮應用程序所需功能的等級,以確定使用DataSet或者是DataReader。

  要通過應用程序執行以下操作,就要使用DataSet:

  1) 在結果的多個離散表之間進行導航。

  2) 操作來自多個數據源(例如,來自多個數據庫、一個xml文件和一個電子表格的混合數據)的數據。

  3) 在各層之間交換數據或使用XML Web服務。與DataReader不同的是,DataSet能傳遞給遠程客戶端。

  4) 重用同樣的記錄集合,以便通過緩存獲得性能改善(例如排序、搜索或篩選數據)。

  5) 每條記錄都需要執行大量處理。對使用DataReader返回的每一行進行擴展處理會延長服務於DataReader的連接的必要時間,這影響了性能。

  6) 使用XML操作對數據進行操作,例如可擴展樣式表語言轉換(XSLT轉換)或XPath查詢。

  對於下列情況,要在應用程序中使用DataReader:

  1) 不需要緩存數據。

  2) 要處理的結果集太大,內存中放不下。

  3) 一旦需要以僅向前、只讀方式快速訪問數據。

  注填充DataSet時,DataAdapter使用DataReader。因此,使用DataAdapter取代DataSet提升的性能表現為節省了DataSet占用內存和填充DataSet需要的循環。一般來說,此性能提升只是象征性的,因此,設計決策應以所需功能為基礎。

  使用強類型DataSet的好處

  DataSet的另一個好處是可被繼承以創建一個強類型DataSet。強類型DataSet的好處包括設計時類型檢查,以及Microsoft Visual Studio.NET用於強類型DataSet語句結束所帶來的好處。修改了DataSet的架構或關系結構後,就可以創建一個強類型DataSet,將行和列作為對象的屬性公開,而不是作為集合中的項公開。例如,不公開客戶表中行的姓名列,而公開Customer對象的Name屬性。類型化DataSet從DataSet類派生,因此不會犧牲DataSet的任何功能。也就是說,類型化DataSet仍能遠程訪問,並作為數據綁定控件(例如DataGrid)的數據源提供。如果架構事先不可知,仍能受益於通用DataSet的功能,但卻不能受益於強類型DataSet的附加功能。

  處理強類型DataSet中的空引用

  使用強類型DataSet時,可以使用DataSet的XML架構定義語言(XSD)架構來確保強類型DataSet可以正確處理空引用。nullValue標識符使您可用一個指定的值String.Empty代替DBNull、保留空引用或引發異常。選擇哪個選項取決於應用程序的上下文。默認情況下,如果遇到空引用,就會引發異常。

  刷新DataSet中的數據

  如果想用服務器上的更新值刷新DataSet中的值,就使用DataAdapter.Fill。如果有在DataTable上定義的主鍵,DataAdapter.Fill會根據主鍵進行新行匹配,並且當更改到現有行時應用服務器上的值。即使刷新之前修改了這些數據,刷新行的RowState仍被設置為Unchanged。注意,如果沒有為DataTable定義主鍵,DataAdapter.Fill就用可能重復的主鍵值添加新行。

  如果想用來自服務器的當前值刷新表,並同時保留對表中的行所做的任何更改,必須首先用DataAdapter.Fill填充表,並填充一個新的DataTable,然後用preserveChanges值true將DataTable合並到DataSet之中。

  在DataSet中搜索數據

  在DataSet中查詢與特定條件相匹配的行時,可以利用基於索引的查找提高搜索性能。當將PrimaryKey值賦給DataTable時,會創建一個索引。當給DataTable創建DataView時,也會創建一個索引。下面是一些利用基於索引進行查找的技巧。

  1) 如果對組成DataTable的PrimaryKey的列進行查詢,要使用DataTable.Rows.Find而不是DataTable.Select。

  2) 對於涉及到非主鍵列的查詢,可以使用DataView為數據的多個查詢提高性能。當將排序順序應用到DataView時,就會建立一個搜索時使用的索引。DataView公開Find和FindRows方法,以便查詢基礎DataTable中的數據。

  3) 如果不需要表的排序視圖,仍可以通過為DataTable創建DataView來利用基於索引的查找。注意,只有對數據執行多個查詢操作時,這樣才會帶來好處。如果只執行單一查詢,創建索引所需要的處理就會降低使用索引所帶來的性能提升。

  DataView構造

  如果創建了DataView,並且修改了Sort、RowFilter或RowStateFilter屬性,DataView就會為基礎DataTable中的數據建立索引。創建DataView對象時,要使用DataView構造函數,它用Sort、RowFilter和RowStateFilter值作為構造函數參數(與基礎DataTable一起)。結果是創建了一次索引。創建一個“空”DataView並隨後設置Sort、RowFilter或RowStateFilter屬性,會導致索引至少創建兩次。

  ADO.NET可以顯式控制從數據源中返回什麼樣的數據,以及在DataSet中本地緩存多少數據。對查詢結果的分頁沒有唯一的答案,但下面有一些設計應用程序時應該考慮的技巧。

  1) 避免使用帶有startRecord和maxRecords值的DataAdapter.Fill重載。當以這種方式填充DataSet時,只有maxRecords參數(從startRecord參數標識的記錄開始)指定的記錄數量用於填充DataSet,但無論如何總是返回完整的查詢。這就會引起不必要的處理,用於讀取“不需要的”記錄;而且為了返回附加記錄,會耗盡不必要的服務器資源。

  2) 用於每次只返回一頁記錄的技術是創建SQL語句,將WHERE子句以及ORDER BY子句和TOP謂詞組合起來。此技術取決於存在一種可唯一標識每一行的辦法。當浏覽下一頁記錄時,修改WHERE子句使之包含所有唯一標識符大於當前頁最後一個唯一標識符的記錄。當浏覽上一頁記錄時,修改WHERE子句使之返回所有唯一標識符小於當前頁第一個唯一標識符的記錄。兩種查詢都只返回記錄的TOP頁。當浏覽上一頁時,需要以降序為結果排序。這將有效地返回查詢的最後一頁(如果需要,顯示之前也許要重新排序結果)。

  3) 另一項每次只返回一頁記錄的技術是創建SQL語句,將TOP謂詞和嵌入式SELECT語句的使用結合在一起。此技術並不依賴於存在一種可唯一標識每一行的辦法。使用這項技術的第一步是將所需頁的數量與頁大小相乘。然後將結果傳遞給SQL Query的TOP謂詞,該查詢以升序排列。再將此查詢嵌入到另一個查詢中,後者從降序排列的嵌入式查詢結果中選擇TOP頁大小。實質上,返回的是嵌入式查詢的最後一頁。例如,要返回查詢結果的第三頁(頁大小是10),應該書寫如下所示的命令:

  SELECT TOP 10 * FROM

  (SELECT TOP 30 * FROM Customers ORDER BY Id ASC) AS Table1

  ORDER BY Id DESC

  注意:從查詢中返回的結果頁以降序顯示。如果需要,應該重新排序。

  1) 如果數據不經常變動,可以在DataSet中本地維護一個記錄緩存,以此提高性能。例如,可以在本地DataSet中存儲10頁有用的數據,並且只有當用戶浏覽超出緩存第一頁和最後一頁時,才從數據源中查詢新數據。

  用架構填充DataSet

  當用數據填充DataSet時,DataAdapter.Fill方法使用DataSet的現有架構,並使用

copyright © 萬盛學電腦網 all rights reserved