使用while循环遍历sqldatareader

3

我想从名为PoliceAccount的表中获取当handle列等于下拉列表的值时,policeidfullname两个字段,并将值放入标签中进行显示。然而,使用下方提供的代码,我只能得到最后一行policeidfullname的结果。但是,我的表格中包含两个具有handle列等于下拉列表值的警务账户。请帮助解决问题。谢谢!

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();
1个回答

4

你需要将值放入一个集合中(列表等):

    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);

我该如何将所有结果输出并显示在标签上? - XiAnG
myData是从数据库检索到的字符串列表。要将它们全部显示为连接字符串,请参见编辑部分。 - Rex

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接