[英]how to retrieve data from sql server to DataTable using c#
string j = "Data Source=FUJITSU-PC\\SQLEXPRESS;Initial Catalog=attendance_system;Integrated Security=True";
DataTable dt = new DataTable();
using (SqlConnection cn = new SqlConnection(j))
{
SqlCommand cmd = new SqlCommand("select dbo.faculty_status.username from dbo.faculty_status", cn);
cn.Open();
SqlDataReader dr = cmd.ExecuteReader();
dr.Read();
dt.Load(dr);
cn.Close();
}
int x = dt.Rows.Count;
foreach (DataRow row in dt.Rows)
{
foreach (var item in row.ItemArray)
{
string xx = item.ToString();
}
}
我使用了它很討厭的這段代碼,但是它並沒有顯示我想要的第一行值,它給了我這樣的提示----
13-24516-2
我認為問題在於您的閱讀方式。 嘗試這個:
string j = "Data Source=FUJITSU-PC\\SQLEXPRESS;Initial Catalog=attendance_system;Integrated Security=True";
using (SqlConnection cn = new SqlConnection(j))
{
SqlCommand cmd = new SqlCommand("select dbo.faculty_status.username from dbo.faculty_status", cn);
cn.Open();
using (var reader = cmd.ExecuteReader())
{
while(reader.Read())
{
Console.WriteLine(reader["username"]);
}
}
}
讓我知道它是否有效!
它給您最后一行。 XX字符串首先加載第一個結果,然后在第二行上用第二行覆蓋第一行,只要有行就繼續執行。
如果要顯示第一行,可以使用類似以下的內容:
DataTable dt = new DataTable();
string xx = dt.Rows[0].ToString();
要么
foreach (DataRow row in dt.Rows)
{
foreach (var item in row.ItemArray)
{
Console.WriteLine(item.ToString());
}
}
dt.Rows [您要檢索的行]
試試這個代碼示例:
SqlCommand cmd = new SqlCommand("select dbo.faculty_status.username from dbo.faculty_status", cn);
DataTable dt = new DataTable();
SqlDataAdapter mda = new SqlDataAdapter(cmd);
mda.Fill(dt);
讓我知道它是否有效!
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.