C#使用SQL DataReader訪問數(shù)據(jù)的優(yōu)點和實例
DataReader
DataReader對象提供了用順序的,只讀的方式讀取Command對象獲得的數(shù)據(jù)結果集,正是因為DataReader是以順序的方式連續(xù)的讀取數(shù)據(jù),所有DataReader會以獨占的方式打開數(shù)據(jù)庫的連接
由于DataReader只執(zhí)行讀的操作(只讀),并且每次只在內存緩沖區(qū)里存儲結果集中的一條數(shù)據(jù),所有使用DataReader的對象的效率比較高,如果要查詢大量數(shù)據(jù),同時不需要隨機訪問和修改數(shù)據(jù),DataReader是優(yōu)先的選擇
DataReader 對象的常用屬性
- FieldCount 屬性 表示記錄中有多少字段
- HasRows 屬性 用來表示DataReader是否包含數(shù)據(jù)
- IsClosed 屬性 表示DataReader是否關閉
DataReader對象常用方法
- Close 方法 將DataReader對象關閉
- GetDataTypName 方法 取得指定的字段數(shù)據(jù)形態(tài)(類型)
- GetName 方法 取得指定的字段數(shù)據(jù)名稱
- GetOrdinal 方法 取得指定字段名稱在記錄中的順序
- GetValue 方法 取得指定字段的數(shù)據(jù)
- GetValues 方法 取得全部字段的數(shù)據(jù)
- Read 方法 讀取下一條記錄
實例 :
mytable01表中有Id,姓名(name),年齡(age),性別(gender),部門(department),幾個字段,并且有幾條語句
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("獲取對應列的名稱:(第一列)"+mydr.GetName(0)); string mystr = "age"; //直接寫會報異常,需要有個轉換的過程 Console.WriteLine(mydr.GetOrdinal(mystr)); /* 此時將上面的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 對象時使用索引要比字段名稱快很多 while (mydr.Read()) { Console.WriteLine(mydr[0].ToString()+","); Console.WriteLine(mydr[1].ToString() + ","); Console.WriteLine(mydr["gender"].ToString()); } //----------------屬性---------------------- Console.WriteLine("表中有幾個字段:"+mydr.FieldCount); Console.WriteLine("是否關閉:"+mydr.IsClosed); mydr.Close(); Console.WriteLine("是否關閉:" + mydr.IsClosed); } catch(Exception ex) { Console.WriteLine(ex.Message.ToString()); } finally { myCon.Close(); } Console.Read(); } } }
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對我們的支持。如果你想了解更多相關內容請查看下面相關鏈接
上一篇:C#抽象類與抽象方法詳解
欄 目:C#教程
本文標題:C#使用SQL DataReader訪問數(shù)據(jù)的優(yōu)點和實例
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5039.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實現(xiàn)手動對資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#使用windows服務開啟應用程序的方法
- 01-10c# ArrayList的使用方法小總結
- 01-10C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫的方法
- 01-10C#使用Mutex簡單實現(xiàn)程序單實例運行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#將圖片存放到SQL SERVER數(shù)據(jù)庫中的方法
- 01-10C#中實現(xiàn)一次執(zhí)行多條帶GO的sql語句實例
- 01-10C#訪問SQL Server數(shù)據(jù)庫的實現(xiàn)方法


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