溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在C#中使用sqlDataRead遍歷讀取各個字段數(shù)值

發(fā)布時間:2021-05-19 16:33:34 來源:億速云 閱讀:303 作者:Leah 欄目:編程語言

這篇文章將為大家詳細講解有關(guān)怎么在C#中使用sqlDataRead遍歷讀取各個字段數(shù)值,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

數(shù)據(jù)庫的查詢分析器中寫上如下代碼:

create table studentname
(
 id int  primary key identity(1,1) not null ,
name nvarchar(500) not null
)
insert into studentname values('long')
insert into studentname values('long')
insert into studentname values('long')
insert into studentname values('long')
insert into studentname values('long')
insert into studentname values('chao')
insert into studentname values('chao')

--sql server 2012 通過。

---------------------------------------------------------------------------------------------------

以下是第一種方法:

using System.Data;
 using System.Data.SqlClient;
string constr = "server=localhost;uid=sa;pwd=longshicheng;database=Student";
      SqlConnection conn = new SqlConnection(constr);
      SqlCommand cmd = new SqlCommand("select * from studentname", conn);
      conn.Open();
      SqlDataReader rdr = cmd.ExecuteReader();
      string makestr = "";
      DataTable table = new DataTable();
      table.Load(rdr); //數(shù)據(jù)表裝入 dataReader 。
      string result="";
      for (int i = 0; i < table.Rows.Count; i++) // 遍歷行
      {
        for (int j = 0; j < table.Columns.Count; j++) //遍歷列
        {
          result += table.Rows[i][j].ToString(); //逐行逐列顯示每個單元格的數(shù)值。
        }
        result += Environment.NewLine; //一行遍歷完成就寫入回車。
      }
      txtlab.Text = result;
      /***************************************************************/

以下是第二種方法:         

string constr = "server=localhost;uid=sa;pwd=longshicheng;database=Student";
      SqlConnection conn = new SqlConnection(constr);
      SqlCommand cmd = new SqlCommand("select * from studentname", conn);
      conn.Open();
      SqlDataReader rdr = cmd.ExecuteReader();
      string makestr = "";
      for (int k = 0; k < rdr.FieldCount; k++) //獲取字段名稱
      {
        makestr += rdr.GetName(k) + "\t"; //載入字段名稱
      }
      makestr += Environment.NewLine; //換行
      makestr = makestr + "---------------------------------------------"+Environment.NewLine;
      while (rdr.Read()) //逐行讀取每一筆記錄
      {
        for (int t = 0; t < rdr.FieldCount; t++) //逐列讀出
        {
          makestr = makestr + rdr[t].ToString() + "\t"; //累加每一行,也就是逐個字段讀出對應(yīng)的數(shù)值
        }
        makestr = makestr + Environment.NewLine; //又一行
      }
      txtinfo.Text = makestr;
      rdr.Close(); //關(guān)閉
      conn.Close();
    }

以下是第三種方法:

string constr = "server=localhost;uid=sa;pwd=longshicheng;database=Student";
      SqlConnection conn = new SqlConnection(constr);
      SqlCommand cmd = new SqlCommand("select * from studentname", conn);
      conn.Open();
      SqlDataReader rdr = cmd.ExecuteReader();
      string makestr = "";
      for (int k = 0; k < rdr.FieldCount; k++) //獲取字段名稱
      {
        makestr += rdr.GetName(k) + "\t"; //載入字段名稱
      }
      makestr += Environment.NewLine; //換行
      makestr = makestr + "---------------------------------------------" + Environment.NewLine;
      while (rdr.Read()) //逐行讀取每一筆記錄
      {
        makestr = makestr + rdr.GetValue(0) + " \t" + rdr.GetValue(1).ToString() + "\t";
        makestr = makestr + Environment.NewLine;
      }
      txtother.Text = makestr;
      rdr.Close(); //關(guān)閉
      conn.Close();

  以上所有方法運行結(jié)果均如下:

id    name   
---------------------------------------------
1     long  
2     long    
3     long    
4     long     
5     long     
6     chao    
7     chao

C#是什么

C#是一個簡單、通用、面向?qū)ο蟮木幊陶Z言,它由微軟Microsoft開發(fā),繼承了C和C++強大功能,并且去掉了一些它們的復(fù)雜特性,C#綜合了VB簡單的可視化操作和C++的高運行效率,以其強大的操作能力、優(yōu)雅的語法風(fēng)格、創(chuàng)新的語言特性和便捷的面向組件編程從而成為.NET開發(fā)的首選語言,但它不適用于編寫時間急迫或性能非常高的代碼,因為C#缺乏性能極高的應(yīng)用程序所需要的關(guān)鍵功能。

關(guān)于怎么在C#中使用sqlDataRead遍歷讀取各個字段數(shù)值就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI