首先,我想声明我正在使用数据表来填充我的gridview,而我正在使用的选择是左连接。这是我的select
SELECT PM.num [num], PMT.MedType [MedType],
...Some other columns...
FROM [pharm_meds] PM
LEFT JOIN [pharm_meds_Type] PMT ON PM.[MedType_ID] = PMT.[num]
我很懒,目前有asp:DropDownList
由位于gridview外的sqldatasource填充
<asp:TemplateField ItemStyle-Width = "75px" HeaderText = "Med Type">
<ItemTemplate>
<asp:Label ID="lblMedType" runat="server" Text='<%# Eval("MedType")%>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:DropDownList ID="ddlMedType" DataSourceID="sdsMedType" DataTextField="MedType" DataValueField="MedType" SelectedValue='<%# Bind("num") %>' Text='<%# Bind("num") %>' runat="server">
</asp:DropDownList>
</EditItemTemplate>
<FooterTemplate>
<asp:DropDownList ID="ddlMedType" DataSourceID="sdsMedType" DataTextField="MedType" DataValueField="MedType" SelectedValue='<%# Bind("num") %>' Text='<%# Bind("num") %>' runat="server" OnSelectedIndexChanged="ddlMedType_SelectedIndexChanged" AutoPostBack="True" >
</asp:DropDownList>
</FooterTemplate>
<ItemStyle Width="75px" />
</asp:TemplateField>
这是asp:DropDownList
:
<asp:SqlDataSource ID="sdsMedType" runat="server" ConnectionString="<%$ ConnectionStrings:SiteSqlServer2 %>" SelectCommand="SELECT [num], [MedType] FROM [pharm_meds_Type]"></asp:SqlDataSource>
现在,当我想编辑现有行时,我遇到的麻烦就是我的代码
protected void EditMedication(object sender, GridViewEditEventArgs e)
{
DropDownList ddlMedType = (DropDownList)gvMainView.FooterRow.FindControl("ddlMedType");
string strMedID = ddlMedType.Text;
using (SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["SiteSqlServer2"].ConnectionString))
{
SqlCommand cmd1 = new SqlCommand("SELECT [num], [MedType] from [pharm_meds_Type] where [MedType] = @MedID", con);
cmd1.Parameters.AddWithValue("@MedID", strMedID);
con.Open();
using (SqlDataReader reader1 = cmd1.ExecuteReader())
{
while (reader1.Read())
{
MyMedType = reader1.GetInt32(0);
}
ddlMedType.SelectedValue = Convert.ToString(MyMedType); //failed attempt to fix the issue
gvMainView.EditIndex = e.NewEditIndex;
BindData();
}
}
}
当我点击编辑链接时,我在标题中收到错误。我该如何解决这个问题?
答案 0 :(得分:0)
出现此错误的一个原因是,下拉列表写入的SQL表具有的值不会包含在下拉列表值中。一个更常见的错误是数字和小数的差异。例如,0.8和0.800是下拉列表中的两个不同数字。如果第一个十进制值是下拉列表选项的一部分,并且在下拉列表写入的列中有0.800,则会抛出该错误。
基本上,如果dropdownlist写入的列中有特定值,并且它不属于下拉列表,则会抛出此错误。
要解决此问题,您必须删除下拉列表,编辑gridview,并确保数据库中的所有值都相同。无论是手动还是编辑数据库。