【问题标题】:Binding Drop Down List from Code behind using C#使用 C# 从代码后面绑定下拉列表
【发布时间】:2014-02-04 02:43:09
【问题描述】:

我正在尝试从后面的代码绑定下拉框,但出现编译错误:

“System.Web.UI.WebControls.SqlDataSource”不包含“DataSource”的定义

我试图弄清楚,但似乎无法解决这个问题。

<asp:DropDownList ID="MYDDL" Width="300px" DataTextField="PRJ_TITLE" AutoPostBack="true"
                  DataValueField="PRJ_ID" runat="server">
</asp:DropDownList> 

这是我的功能:

private void Bind_DD()
{
    String strConnString = System.Configuration.ConfigurationManager.ConnectionStrings["myCon"].ConnectionString;
    SqlConnection con2 = new SqlConnection(strConnString);
    SqlDataAdapter sda = new SqlDataAdapter();
    SqlCommand cmd1 = new SqlCommand("SELECT  ID, PRJ_TITLE FROM myTable");

    cmd1.Connection = con2;
    con2.Open();

    myDDL.DataSource = cmd1.ExecuteReader();
    myDDL.DataTextField = "PRJ_TITLE";
    myDDL.DataValueField = "ID";
    myDDL.DataBind();

    con2.Close();

}

【问题讨论】:

  • 请发布所有相关代码。在当前的 sn-p 中没有提到 SqlDataSource 控件。
  • 你为什么要绑定两次数据?
  • Andrei,我在 aspx 中没有 sql 数据源,这就是为什么我试图将它绑定到后面的代码中。我不确定我在这里做错了什么。谢谢
  • Josh,你刚刚更新了我的代码。谢谢
  • @moe,第一种情况的代码是什么?代码隐藏方法有什么问题?

标签: c# asp.net


【解决方案1】:

所以看起来您可能对 sql 数据连接有点混淆,因为有很多方法可以做到这一点。我选择通过 sqlDataAdapter 对 DataTable 进行数据记录。

另外确保您的标记中没有任何元素在您的标记中的任何位置具有 asp:SqlDataSource。

private void Bind_DD()
{
    DataTable dt = new DataTable();

    using(SqlConnection con2 = new SqlConnection(ConfigurationManager.ConnectionStrings["myCon"].ConnectionString))
    {
        con2.Open();

        SqlCommand cmd1 = new SqlCommand("SELECT  ID, PRJ_TITLE FROM myTable",con2);
        SqlDataAdapter sda = new SqlDataAdapter(cmd1);
        sda.Fill(dt);
    }

    myDDL.DataSource = dt;
    myDDL.DataTextField = "PRJ_TITLE";
    myDDL.DataValueField = "ID";
    myDDL.DataBind();

}

【讨论】:

    【解决方案2】:

    试试这个:

    private void Bind_DD()
    {
        String strConnString = System.Configuration.ConfigurationManager.ConnectionStrings["myCon"].ConnectionString;
        SqlConnection con2 = new SqlConnection(strConnString);
    
        DataSet ds = new DataSet();
        SqlCommand cmd1 = new SqlCommand("SELECT  ID, PRJ_TITLE FROM myTable");
        cmd1.Connection = con2;
        con2.Open();
        SqlDataAdapter sda = new SqlDataAdapter(cmd1);
        sda.Fill(ds);
        myDDL.DataSource = ds; //cmd1.ExecuteReader();
        myDDL.DataTextField = "PRJ_TITLE";
        myDDL.DataValueField = "ID";
        myDDL.DataBind();
        con2.Close();
        //myDDL.DataBind(); 
     }
    

    【讨论】:

      猜你喜欢
      • 2013-10-01
      • 2015-01-21
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多