我有以下网格:
<asp:GridView DataSourceID="accountsDataSource" DataKeyNames="Id" ShowEditButton="true" ...>
<asp:TemplateField HeaderText="Name">
<ItemTemplate>
<asp:Hyperlink ID="lnkGridEditEntry" runat="server" Text='<%# Bind("Name")%>' NavigateUrl="..." />
</ItemTemplate>
<EditItemTemplate>
<asp:TextBox ID="txtGridAccountName" runat="server" Text='<%# Bind("Name") %>' />
</EditItemTemplate>
</asp:TemplateField>
</asp:GridView>
<asp:SqlDataSource ID="accountsDataSource" SelectCommand= "..." DeleteCommand= "..." UpdateCommand="update Account set [Name]=@Name where [Id]=@Id">
<UpdateParameters>
<asp:Parameter Name="Name" />
<asp:Parameter Name="Id" />
</UpdateParameters>
</asp:SqlDataSource>
当我点击“编辑”按钮并尝试更新名称时,上面的代码永远不会更新名称
当我将名称更新参数更改为
时<asp:ControlParameter ControlID="txtGridAccountName" Name="Name" PropertyName="Text" Type="String" />
页面崩溃,“无法在ControlParameter名称中找到控件txtGridAccountName”。我相信这是因为当渲染网格时,模板字段中的文本框会获得不同的ID(类似于ct100 $ txtGridAccountName $ ..),显然它找不到。
首先将accout名称呈现为模板字段,因为我将其显示为指向详细信息/交易页面的链接。
如果我删除模板字段并显示名称,则可以使用。
感谢您解决此问题的任何帮助。
答案 0 :(得分:0)
要自己调试,您应该同时连接SQL数据源Updating事件和gridview行更新事件以检查问题。
无论如何,在不知道您的数据库设计的情况下,我的猜测是您在更新参数上缺少类型。尝试这样的事情:
<UpdateParameters>
<asp:Parameter Name="Name" Type="String" />
<asp:Parameter Name="Id" Type="Int64" />
</UpdateParameters>