Droplist有一个SelectedValue,它是无效的,因为它在项目列表中不存在

时间:2013-12-26 19:47:05

标签: c# asp.net sql gridview

首先,我想声明我正在使用数据表来填充我的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

的sqldatasource
<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();
            }
        }

    }

当我点击编辑链接时,我在标题中收到错误。我该如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

出现此错误的一个原因是,下拉列表写入的SQL表具有的值不会包含在下拉列表值中。一个更常见的错误是数字和小数的差异。例如,0.8和0.800是下拉列表中的两个不同数字。如果第一个十进制值是下拉列表选项的一部分,并且在下拉列表写入的列中有0.800,则会抛出该错误。

基本上,如果dropdownlist写入的列中有特定值,并且它不属于下拉列表,则会抛出此错误。

要解决此问题,您必须删除下拉列表,编辑gridview,并确保数据库中的所有值都相同。无论是手动还是编辑数据库。