欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

C#中怎么實現(xiàn)ADO.NET離線查詢

這篇文章主要講解了C#中怎么實現(xiàn)ADO.NET離線查詢,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

專注于為中小企業(yè)提供成都網(wǎng)站建設(shè)、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)縉云免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

0. 前言

可以通過以下代碼獲取一個DataReader:

IDataReader reader = command.ExecuteReader();

然后通過reader一行一行的讀取數(shù)據(jù),但是我并不推薦這樣使用。

在查詢這一高頻需求上,C#為之做了很多工作,提供了更多的選擇。這里介紹一個查詢的另一套寫法。

1. 離線查詢

C#在查詢上提供了另一種機制,可以一次性從數(shù)據(jù)庫把結(jié)果讀取到網(wǎng)絡(luò)緩存區(qū)中,直到使用的時候才加載到程序中。

在離線查詢里最關(guān)鍵的三個接口或類:

  • IDataAdapter 一種適配器,用來獲取數(shù)據(jù)并填充或更新DataSet
  • DataSet 表示數(shù)據(jù)在內(nèi)存中的緩存
  • DataTable 表示內(nèi)存中一個數(shù)據(jù)表

IDataAdapter用來提供數(shù)據(jù),DataSet表示adapter讀取的結(jié)果集,其中有一個DataTable集合表示執(zhí)行的SQL查詢結(jié)果。至于為什么是集合,是因為IDataAdapter允許運行多條查詢語句。

好,讓我們粗略瀏覽一下這個三個關(guān)鍵點的屬性和方法:

IDataAdapter:

public int Fill (System.Data.DataSet dataSet);//將查詢出來的結(jié)果填充到DataSet里

在C#內(nèi)部,其實不允許推薦直接繼承該接口,推薦繼承DataAdapter類,該類規(guī)定了數(shù)據(jù)庫Adapter在初始化的時候,必須提供一個可以訪問的數(shù)據(jù)庫連接和要執(zhí)行的命令文本。

當(dāng)然其部分實現(xiàn)類允許以屬性的形式后賦值這兩個關(guān)鍵內(nèi)容。

DataSet:

public DataSet ();
public DataSet (string dataSetName);//指定數(shù)據(jù)集的名稱
public System.Data.DataTableCollection Tables { get; }//獲取包含在 DataSet 中的表的集合

DataSet有很多有用的方法,但是在今天我們只用關(guān)系這些就可以了。

其中Tables 引入了一個沒有提到的類型,DataTableCollection。那么我們可以順藤摸瓜,來看看里面有什么關(guān)鍵的內(nèi)容:

public System.Data.DataTable this[int index] { get; }// 獲取指定下標的DataTable
public System.Data.DataTable this[string name] { get; }//獲取具有指定名稱的DataTable

可以看到提供了一種我們可以獲取到里面的DataTable元素的索引訪問方式。

DataTable :

public System.Data.DataSet DataSet { get; }//獲取此表所屬的 DataSet。
public System.Data.DataColumnCollection Columns { get; }//獲取屬于該表的列的集合
public System.Data.DataRowCollection Rows { get; }//獲取屬于該表的行的集合

又出現(xiàn)了兩個新的類:DataColumnCollection、DataRowCollection。這是一種內(nèi)部集合的實現(xiàn)類,功能類似于List,但又不等同于List。

我們大概看一下對我們有用的屬性和方法:

DataColumnCollection:

public virtual int Count { get; }//獲取集合中的元素總數(shù)
public System.Data.DataColumn this[int index] { get; }//從集合中獲取位于指定索引位置的 DataColumn
public System.Data.DataColumn this[string name] { get; }//從具有指定名稱的集合中獲取 DataColumn。

DataRowCollection:

public override int Count { get; }
public System.Data.DataRow this[int index] { get; }// 獲取索引處的行

嗯,好先到此為止。調(diào)轉(zhuǎn)方向回到上個路口,重新來。讓我們看看DataColumn和DataRow又有哪些值得我們現(xiàn)在關(guān)注的:

DataColumn:

public string ColumnName { get; set; }//獲取或設(shè)置 DataColumnCollection 中的列的名稱
public Type DataType { get; set; }//獲取或設(shè)置存儲在列中的數(shù)據(jù)的類型

DataRow:

public object this[System.Data.DataColumn column] { get; set; }//獲取或設(shè)置指定 DataColumn 中存儲的數(shù)據(jù)
public object this[int columnIndex] { get; set; }//獲取或設(shè)置由索引指定的列中存儲的數(shù)據(jù)
public object this[string columnName] { get; set; }//獲取或設(shè)置由名稱指定的列中存儲的數(shù)據(jù)
public object[] ItemArray { get; set; }//通過數(shù)組獲取或設(shè)置此行的所有值

到目前為止,離線查詢的支持類和接口就介紹了個大概。那么我們看看如何進行一個離線查詢吧

2.實踐看看

以SQL Server數(shù)據(jù)庫為例:

獲取一個SqlDataAdapter,C#提供了四種方式獲?。?/p>

public SqlDataAdapter ();//構(gòu)造一個沒有連接和命令的Adapter對象
public SqlDataAdapter (System.Data.SqlClient.SqlCommand selectCommand);// 指定一個查詢命令
public SqlDataAdapter (string selectCommandText, System.Data.SqlClient.SqlConnection selectConnection);//指定查詢命令,和連接
public SqlDataAdapter (string selectCommandText, string selectConnectionString);//指定查詢命令和連接字符串

引用命名空間:

using System.Data;
using System.Data.SqlClient;

那么,我們先構(gòu)造一個Adapter:

var connectStr = "Data Source=.;Initial Catalog=Old;Integrated Security=True";
var sql = "select * from Area_PostCode";
var adapter = new SqlDataAdapter(sql, connectStr);

然后創(chuàng)建一個用于保存數(shù)據(jù)的DataSet,并把數(shù)據(jù)填充進去:

DataSet set = new DataSet();
adapter.Fill(set);

然后可以看到這個set中的數(shù)據(jù)應(yīng)該是這樣的:

C#中怎么實現(xiàn)ADO.NET離線查詢

上圖是在VS中的調(diào)試模式中,可以看到

根據(jù)上圖我們大概可以猜測一下DataTable內(nèi)部的數(shù)據(jù)結(jié)構(gòu),或者C#讓我們理解的結(jié)構(gòu)是什么。

其中DataColumn對應(yīng)著圖中列,ColumnName就是圖 所示的列名。而DataRow就是行,ItemArray則是一行行數(shù)據(jù)。

這樣一來,顯然就比直接使用IDataReader訪問數(shù)據(jù)要方便很多。

依據(jù)上例:

我們試著獲取一下第三行的Province列值,如果覺得這個表述別扭的話,看一下我的寫法,就知道我為什么這么表示了。

var table = set.Tables[0];// 先拿到第一個表
var value = table.Rows[2]["Province"];

這是一種螞蟻搬家式的讀取數(shù)據(jù)方式。C#為DataTable提供了一個擴展方法:

public static EnumerableRowCollection<DataRow> AsEnumerable(this DataTable source);

將表格轉(zhuǎn)換成可枚舉的DataRow集合。

所以我們可以用foreach循環(huán)來遍歷DataTable。

3. 未完待續(xù)

在這一節(jié)簡單介紹了一下ADO.NET的離線查詢支持。當(dāng)我們能從數(shù)據(jù)庫中獲取到DataTable的時候,我們就能通過這個做出更多的事情來。下一章我將帶領(lǐng)大家結(jié)合之前介紹的反射,實現(xiàn)一個簡單的ORM工具類。

看完上述內(nèi)容,是不是對C#中怎么實現(xiàn)ADO.NET離線查詢有進一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁題目:C#中怎么實現(xiàn)ADO.NET離線查詢
當(dāng)前網(wǎng)址:http://aaarwkj.com/article16/gghgdg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、ChatGPT、企業(yè)建站、品牌網(wǎng)站建設(shè)、App開發(fā)靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
久久精品国产一区二区三| 亚洲欧美综合另类久久| 国产精品剧情在线播放| 亚洲av中文久久精品国内| av在线免费播放观看| 加勒比久久精品网址系列| 久久伊人69日韩精品| 神马视频一区二区在线观看| 国产丰满熟女视频免费| 手机在线观看av网站| 欧美日韩在线一区二区| 在线观看高清国产黄色片| 中文字幕一区二区三区网站| 午夜视频在线看一区免费| 日本一区二区三区日韩欧美| 国产三级网站在线观看| 午夜在线观看成人av| 欧美高清一区二区三区精品| 日本一区二区三区加勒比| 国产精彩在线视频成人在线 | 偷拍丝袜美腿在线观看| 国产亚洲精品久在线| 欧美一区二区三区爽| 久久久久久狠狠亚洲综合| 国产自拍成人精品视频| 日韩视频播放一区二区| 天天操天天夜夜操夜夜| 6080yy精品一区二区三区| 精品欧美一区二区三久久| 人妻熟女在线一区二区| 国产日韩亚洲欧美色片| 午夜福利视频在线观看| 久久热在线视频精品视频| 亚洲成人久久久久久久| 亚洲综合欧美自偷自拍| 精品国产91久久粉嫩| 亚洲高清成人在线观看| av剧情网址在线观看| 成人黄色一级电影免费看| 亚洲午夜福利天堂社区| 69国产精品久久久久久人|