ASP.NET не может найти объект в параметре ControlParameter
Я пытаюсь получить значение из DropDownList в качестве параметра для запроса SQL. У меня есть GridView и SqlDataSource. И я не могу добраться до DropDownList ("DDLName") внутри GridView. Когда "DDLName" находится за пределами GridView, все работает, но когда я помещаю его внутрь, я получаю сообщение об ошибке, в котором говорится, что не удается найти "DDLName". Я хочу сделать это в.aspx. Я видел много советов по использованию "$, но я пытался использовать"GridView1$DDLName", и он не работает.
Вот мой код:
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="id" DataSourceID="SqlDataSource2" AutoGenerateEditButton="True" ShowFooter="True">
<Columns>
<asp:BoundField DataField="id" HeaderText="id" ReadOnly="True" SortExpression="id" />
<asp:BoundField DataField="firstname" HeaderText="firstname" SortExpression="firstname" />
<asp:BoundField DataField="lastname" HeaderText="lastname" SortExpression="lastname" />
<asp:TemplateField HeaderText="city">
<ItemTemplate>
<asp:Label ID = "LabelName" runat="server" Text='<%# Eval("name") %>'></asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:DropDownList ID = "DDLName" runat="server" DataSourceID="DDLSource" DataTextField="name" ClientIDMode="Static"></asp:DropDownList>
</EditItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
<asp:SqlDataSource ID="DDLSource" runat="server" ConnectionString="<%$ ConnectionStrings:MBase1ConnectionString %>" SelectCommand="SELECT [name] FROM [cities]">
</asp:SqlDataSource>
<asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString="<%$ ConnectionStrings:MBase1ConnectionString %>" SelectCommand="users_select_all_city" SelectCommandType="StoredProcedure" UpdateCommand="users_update_city" UpdateCommandType="StoredProcedure" DeleteCommand="users_delete" DeleteCommandType="StoredProcedure" InsertCommand="users_add" InsertCommandType="StoredProcedure">
<DeleteParameters>
<asp:Parameter Name="id" Type="Int32" />
</DeleteParameters>
<InsertParameters>
<asp:Parameter Name="id" Type="Int32" />
<asp:Parameter Name="firstName" Type="String" />
<asp:Parameter Name="lastName" Type="String" />
<asp:Parameter Name="name" Type="String" />
</InsertParameters>
<UpdateParameters>
<asp:Parameter Name="id" Type="Int32" />
<asp:Parameter Name="firstName" Type="String" />
<asp:Parameter Name="lastName" Type="String" />
<asp:ControlParameter ControlId="DDLName" Name="name" PropertyName="SelectedValue" Type="String" />
</UpdateParameters>
</asp:SqlDataSource>
1 ответ
Решение
Хороший вопрос. Мне потребовалось несколько часов, чтобы решить эту проблему, но я все понял правильно. Вам нужно сделать два изменения.
1) Измените свой раскрывающийся список, чтобы быть таким:
<asp:DropDownList ID="DDLName" runat="server"
DataSourceID="DDLSource"
DataTextField="name"
DataValueField="name"
SelectedValue='<%# Bind("name") %>'>
</asp:DropDownList>
2) Заменить эту строку:
<asp:ControlParameter ControlId="DDLName" Name="name" PropertyName="SelectedValue" Type="String" />
С этим:
<asp:Parameter Name="name" Type="String" />