国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

用DataReader還是DataSet?

2024-07-10 12:40:33
字體:
來源:轉載
供稿:網友
ADO.NET提供了兩個主要的類來讀取數據。通過本文我們可以學習如何在兩者之間進行選擇。 

我經常聽到有人問這個問題:“在ASP.NET Web應用程序中我應該用DataReader類還是DataSet類呢?”在很多文章以及新聞組的貼子中我經常看到這樣的誤解,即認為DataReader(SqlDataReader或OleDbDataReader的縮寫)比DataSet好。有時候我也會看到相反的說法。事實上,Microsoft創建了這兩個數據存取類是因為它們都是我們所需要的。每個類都有其優點和不足,你可以根據應用環境來選擇用哪一個。

本文就兩者的選擇問題做了很清楚的講述,可以讓你在運用ASP.NET時,在選擇DataReader類或DataSet類的方面得到一些指南。在基于客戶端的Windows Form應用程序環境下,這些規則可能會改變。我在做這些講述時,假設你已經用過DataReader和DataSet類了,并對它們很熟悉。

運用DataReader類
下面就是運用DataReader類的理想條件:  你讀取的數據必須是新的,所以在每次需要數據的時候,你都必須從數據庫讀取。創建一個DataReader類不會消耗很多內存,不過隨著負荷的增加,DataSet上的性能也會很快地提高(參考資源中Visual Studio Magazine中的文章)。

 你對每行數據的需求很簡單。該情況的最好的例子就是簡單地將DataReader綁定到一個Web控件,如DataGrid或DropDownList。

 你只需要從數據庫中以只向前的(forward-only) 、只讀的形式來存取XML數據。在這種情況下,你可以用SQLCommand對象的ExcecuteXmlReader()方法來得到一個XmlReader類(相當于XML版的DataReader)。這就需要一個運用FOR XML子句的SQL Server查詢,或者一個包含有效XML的ntext字段。

 你計劃對數據庫進行幾個重復的調用,來讀取一小塊信息。在這種情況下,我們前面提到過的性能數據會有更大的提高。

 的確,使DataSet類更強大的許多功能只適用于基于客戶端的Windows Form應用程序,比如在多個表之間建立關系的功能。在很多情況下,DataSet類都比DataReader類更有優勢,而且在有些情況下,你根本就不能用DataReader類。



運用DataSet類
在下面的情況,你應該考慮運用DataSet類:  你構建了一個Web service,它運用的數據是你作為返回值讀取的數據。因為DataReader類必須保持到數據庫的連接,所以它們不能被序列化到XML中,也不能被發送給一個Web service的調用者。

 你需要排序或篩選數據。在運用一個DataView對象(呈現為DataTable類的DefaultView屬性,它包含一個DataSet類)來排序或篩選數據前,我們先試著用SQL查詢(如WHERE和ORDER BY語句)來實現這些功能,并運用更輕量級、更快的DataReader類。然而,有時侯用這種方法是不行的,或者當你需要多次地對數據進行排序或篩選時就不能用DataReader。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌宁县| 盘锦市| 云林县| 吉首市| 衡阳市| 土默特左旗| 沙湾县| 东光县| 嘉荫县| 客服| 华阴市| 兴山县| 张家界市| 万荣县| 哈巴河县| 平武县| 嵊州市| 万宁市| 尚志市| 拉萨市| 台州市| 惠水县| 同心县| 二连浩特市| 四子王旗| 麻城市| 五指山市| 阳新县| 尉氏县| 鹤岗市| 南投市| 永顺县| 北京市| 高邮市| 泾源县| 铁岭市| 大兴区| 若羌县| 观塘区| 岑巩县| 宜兴市|