我尝试将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");
}
答案 0 :(得分:1)
我认为您提供的是过程参数名称(@statename)而不是列名。您应该将datatextfield和valuefield属性设置为您的数据表包含的相同列名称。