C#使用SQL DataReader訪問數(shù)據(jù)的優(yōu)點(diǎn)和實(shí)例
DataReader
DataReader對(duì)象提供了用順序的,只讀的方式讀取Command對(duì)象獲得的數(shù)據(jù)結(jié)果集,正是因?yàn)镈ataReader是以順序的方式連續(xù)的讀取數(shù)據(jù),所有DataReader會(huì)以獨(dú)占的方式打開數(shù)據(jù)庫(kù)的連接
由于DataReader只執(zhí)行讀的操作(只讀),并且每次只在內(nèi)存緩沖區(qū)里存儲(chǔ)結(jié)果集中的一條數(shù)據(jù),所有使用DataReader的對(duì)象的效率比較高,如果要查詢大量數(shù)據(jù),同時(shí)不需要隨機(jī)訪問和修改數(shù)據(jù),DataReader是優(yōu)先的選擇
DataReader 對(duì)象的常用屬性
- FieldCount 屬性 表示記錄中有多少字段
- HasRows 屬性 用來表示DataReader是否包含數(shù)據(jù)
- IsClosed 屬性 表示DataReader是否關(guān)閉
DataReader對(duì)象常用方法
- Close 方法 將DataReader對(duì)象關(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è)字段,并且有幾條語(yǔ)句
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("獲取對(duì)應(yīng)列的名稱:(第一列)"+mydr.GetName(0));
string mystr = "age"; //直接寫會(huì)報(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 對(duì)象時(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é)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)我們的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
上一篇:C#抽象類與抽象方法詳解
欄 目:C#教程
下一篇:C# 時(shí)間與時(shí)間戳互轉(zhuǎn)的方法(13位)
本文標(biāo)題:C#使用SQL DataReader訪問數(shù)據(jù)的優(yōu)點(diǎn)和實(shí)例
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5039.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動(dòng)對(duì)資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#使用windows服務(wù)開啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫(kù)的方法
- 01-10C#使用Mutex簡(jiǎn)單實(shí)現(xiàn)程序單實(shí)例運(yùn)行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#將圖片存放到SQL SERVER數(shù)據(jù)庫(kù)中的方法
- 01-10C#中實(shí)現(xiàn)一次執(zhí)行多條帶GO的sql語(yǔ)句實(shí)例
- 01-10C#訪問SQL Server數(shù)據(jù)庫(kù)的實(shí)現(xiàn)方法


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?


