如何将表数据绑定到下拉列表?

时间:2015-03-14 19:02:10

标签: c# asp.net

我尝试将tblState数据绑定到下拉列表但数据无法绑定。 我得到了像

这样的错误
  

DataBinding:' System.Data.DataRowView'不包含属性   名称为' @ StateName'。

获取状态的存储过程

CREATE PROCEDURE GetStates
as
select * from tblState

来源

public DataTable GetStates()
{
    cmd = new SqlCommand("GetStates", con);
    cmd.CommandType = CommandType.StoredProcedure;
    da = new SqlDataAdapter(cmd);
    dt = new DataTable();
    da.Fill(dt);
    return dt;
}

aspx页面

Property p = new Property();

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        FillStates();
    }
}

private void FillStates()
{
    ddlState.DataSource = p.GetStates();
    ddlState.DataTextField = "@StateName";
    ddlState.DataValueField = "@Sid";

    ddlState.DataBind();
    ddlState.Items.Insert(0, "Select State");
}

1 个答案:

答案 0 :(得分:1)

我认为您提供的是过程参数名称(@statename)而不是列名。您应该将datatextfield和valuefield属性设置为您的数据表包含的相同列名称。