1

我正在学习 ASP.NET。我想知道cmd.ExecuteReader()' 的输出是否可以临时存储到某个东西中,例如临时变量,以便以后重新使用或更改它。我经常使用临时变量来存储东西。

我怎样才能让 adropbox和 agridview都与cmd.exectuteReader. 我不想为它创建一个新的 SQL 连接。

变量t可能会保留内容,但显然我在这里错了,因为它不起作用。它执行读取器两次,第二次运行时没有数据填充下拉框。

我该怎么做?

 protected void Page_Load(object sender, EventArgs e)
 {
    string cs = System.Configuration.ConfigurationManager.ConnectionStrings["DBCS"].ConnectionString; // reading by name DBCS out of the web.config file
    using (SqlConnection con = new SqlConnection(cs))
    {

      SqlCommand cmd = new SqlCommand("Select * from tblEmployees", con);
      con.Open();

       var t = cmd.ExecuteReader();

       GridView1.DataSource = t;// cmd.ExecuteReader();
       GridView1.DataBind();

        // DropDownList2.DataSource = cmd.ExecuteReader();
        DropDownList2.DataSource = t;//cmd.ExecuteReader();

       DropDownList2.DataTextField = "Name";
       DropDownList2.DataValueField = "EmployeeId";
       DropDownList2.DataBind();
    }
}
4

2 回答 2

1

SqlDataReader是来自 SQL Server 数据库的只进行流。

您可以通过以下方式将 SqlDataReader 绑定到 GridView:

简单的例子:

    connection.Open();
    command.Connection = connection;
    SqlDataReader reader = command.ExecuteReader();
    GridView1.DataSource = reader;
    GridView1.DataBind();

或者:

 DataTable dt = new DataTable();
 dt.Load(cmd.ExecuteReader());
 GridView1.DataSource = dt;

不要忘记配置 Gridview 控件内的列。

于 2016-10-18T14:44:46.947 回答
0

要回答您的问题,它会SqlDataReader按照Msdn 文档中的说明返回 - SqlCommand.ExecuteReader Method ()

您可以查看文档示例以更好地理解ExecuteReader()

您已经将其变成了 XY 问题,但是要将数据绑定到 aGridView您应该使用 aDataTable和 a SqlDataAdapter。一个通用的例子是:

void FillData()
{
    // 1
    // Open connection
    using (SqlConnection c = new SqlConnection(
    Properties.Settings.Default.DataConnectionString))
    {
    c.Open();
    // 2
    // Create new DataAdapter
    using (SqlDataAdapter a = new SqlDataAdapter(
        "SELECT * FROM EmployeeIDs", c))
    {
        // 3
        // Use DataAdapter to fill DataTable
        DataTable t = new DataTable();
        a.Fill(t);

        // 4
        // Render data onto the screen
        // dataGridView1.DataSource = t; // <-- From your designer
    }
}

我暂时不会使用你的代码,你可以对这个例子进行实验。如果您需要进一步的帮助,请在更改代码后编辑您的原始帖子。

于 2016-10-18T14:16:57.143 回答