C#使用SQL DataReader訪問數(shù)據(jù)的優(yōu)點(diǎn)和實(shí)例
DataReader
DataReader對象提供了用順序的,只讀的方式讀取Command對象獲得的數(shù)據(jù)結(jié)果集,正是因?yàn)镈ataReader是以順序的方式連續(xù)的讀取數(shù)據(jù),所有DataReader會以獨(dú)占的方式打開數(shù)據(jù)庫的連接
由于DataReader只執(zhí)行讀的操作(只讀),并且每次只在內(nèi)存緩沖區(qū)里存儲結(jié)果集中的一條數(shù)據(jù),所有使用DataReader的對象的效率比較高,如果要查詢大量數(shù)據(jù),同時(shí)不需要隨機(jī)訪問和修改數(shù)據(jù),DataReader是優(yōu)先的選擇
DataReader 對象的常用屬性
- FieldCount 屬性 表示記錄中有多少字段
- HasRows 屬性 用來表示DataReader是否包含數(shù)據(jù)
- IsClosed 屬性 表示DataReader是否關(guān)閉
DataReader對象常用方法
- Close 方法 將DataReader對象關(guān)閉
- GetDataTypName 方法 取得指定的字段數(shù)據(jù)形態(tài)(類型)
- GetName 方法 取得指定的字段數(shù)據(jù)名稱
- GetOrdinal 方法 取得指定字段名稱在記錄中的順序
- GetValue 方法 取得指定字段的數(shù)據(jù)
- GetValues 方法 取得全部字段的數(shù)據(jù)
- Read 方法 讀取下一條記錄
實(shí)例 :
mytable01表中有Id,姓名(name),年齡(age),性別(gender),部門(department),幾個(gè)字段,并且有幾條語句
using System; using System.Data.SqlClient; namespace DataReaderDemo { class Program { static void Main(string[] args) { string constr = "Server = .; user=name;pwd=mima;database=mysql"; SqlConnection myCon = new SqlConnection(constr); try { myCon.Open(); string sql = "select * from mytable01 "; SqlCommand mycom = new SqlCommand(sql, myCon); //聲明DataReader SqlDataReader mydr; mydr = mycom.ExecuteReader(); if (mydr.HasRows) { Console.WriteLine("mytable01中存在數(shù)據(jù)"); } else { Console.WriteLine("mytable01中不存在任何數(shù)據(jù)"); } //----------------方法---------------------- Console.WriteLine("第一列的數(shù)據(jù)類型"+mydr.GetDataTypeName(0)); Console.WriteLine("獲取對應(yīng)列的名稱:(第一列)"+mydr.GetName(0)); string mystr = "age"; //直接寫會報(bào)異常,需要有個(gè)轉(zhuǎn)換的過程 Console.WriteLine(mydr.GetOrdinal(mystr)); /* 此時(shí)將上面的15行的str,換為 * string sql = "select * from mytable01 where id=1"; if (mydr.Read()) { Console.WriteLine("取得指定字段的數(shù)據(jù):" + mydr.GetValue(0)); } */ /*將15行的 str更改為: * string sql = "select * from mytable01 where gender='男'"; object[] myobj = new object[mydr.FieldCount]; while(myde.Read()){ mydr.GetValues(myobj); foreach (object item in myobj) { Console.Write(item + "\t"); Console.WriteLine(); } } */ //訪問DataReader 對象時(shí)使用索引要比字段名稱快很多 while (mydr.Read()) { Console.WriteLine(mydr[0].ToString()+","); Console.WriteLine(mydr[1].ToString() + ","); Console.WriteLine(mydr["gender"].ToString()); } //----------------屬性---------------------- Console.WriteLine("表中有幾個(gè)字段:"+mydr.FieldCount); Console.WriteLine("是否關(guān)閉:"+mydr.IsClosed); mydr.Close(); Console.WriteLine("是否關(guān)閉:" + mydr.IsClosed); } catch(Exception ex) { Console.WriteLine(ex.Message.ToString()); } finally { myCon.Close(); } Console.Read(); } } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對我們的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
上一篇:C#抽象類與抽象方法詳解
欄 目:C#教程
下一篇:C# 時(shí)間與時(shí)間戳互轉(zhuǎn)的方法(13位)
本文標(biāo)題:C#使用SQL DataReader訪問數(shù)據(jù)的優(yōu)點(diǎn)和實(shí)例
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5039.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動對資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#使用windows服務(wù)開啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫的方法
- 01-10C#使用Mutex簡單實(shí)現(xiàn)程序單實(shí)例運(yùn)行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#將圖片存放到SQL SERVER數(shù)據(jù)庫中的方法
- 01-10C#中實(shí)現(xiàn)一次執(zhí)行多條帶GO的sql語句實(shí)例
- 01-10C#訪問SQL Server數(shù)據(jù)庫的實(shí)現(xiàn)方法


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻 器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05織夢dedecms什么時(shí)候用欄目交叉功能?