【问题标题】:Using while loop for sqldatareader为 sqldatareader 使用 while 循环
【发布时间】:2013-08-08 06:31:57
【问题描述】:

handle 列等于下拉列表的值,然后将值放入标签并显示它。通过使用下面提供的代码,我不断得到 policeidfullname 的最后一行数据的结果。但是,我的表包含 2 个警察帐户,其列 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();

【问题讨论】:

    标签: c# while-loop sqldatareader


    【解决方案1】:

    您必须将值放入集合(列表左右):

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

    【讨论】:

    • 如何将所有结果显示出来并显示在标签上?
    • myData 是您从数据库中检索到的字符串列表。将它们全部显示在一个连接的字符串中 - 请参阅编辑部分
    猜你喜欢
    • 2019-02-10
    • 1970-01-01
    • 2017-02-14
    • 2015-02-16
    • 1970-01-01
    • 2021-07-18
    • 2016-03-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多