对sqldatareader使用while循环
本文关键字:循环 while 使用 sqldatareader | 更新日期: 2023-09-27 18:26:43
当handle列等于下拉列表的值时,我试图从名为PoliceAccount的表中获取policeid和全名,然后将该值放入标签并显示。通过使用下面提供的代码,我不断获得policeid和fullname的最后一行数据的结果。然而,我的表包含2个警察帐户,其列句柄等于下拉列表的值。一定要帮我。谢谢!
conn.Open();
sql = "Select policeid, fullname From PoliceAccount Where handle = '"+ ddlReportDateTime.SelectedValue +"'";
using (var cmd2 = new SqlCommand(sql, conn))
{
SqlDataReader dr;
dr = cmd2.ExecuteReader();
while (dr.Read())
{
String policeid = dr.GetString(0);
String fullname = dr.GetString(1);
String result = policeid + " " + fullname;
lblAssignTo.Text = result;
}
}
conn.Close();
您必须将值放入集合(列表左右):
var myData = new List<string>();
while (dr.Read())
{
String policeid = dr.GetString(0);
String fullname = dr.GetString(1);
String result = policeid + " " + fullname;
myData.Add(result);
}
然后根据需要使用它-显示第一个/最后一个/连接的/等等。。。。
编辑:
显示连接字符串:
yourLabel.Text = myData.Aggregate((x,y)=> x + "; " + y);