【问题标题】:UpdateCommand problem in a TemplateField in asp.net GridViewasp.net GridView 中 TemplateField 中的 UpdateCommand 问题
【发布时间】:2009-09-14 22:39:36
【问题描述】:

我有以下网格:

<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 Name 中找到控件 txtGridAccountName”而崩溃。我相信这是因为模板字段中的文本框在渲染网格时获得了不同的 ID(类似于 ct100$txtGridAccountName$..),但显然没有找到。

帐户名称首先呈现为模板字段,因为我将其显示为详细信息/交易页面的链接。

如果我删除模板字段并按此方式显示名称。

感谢任何帮助解决此问题。

【问题讨论】:

  • 抱歉代码消失了。我将再次编辑代码。
  • 这个问题自行消失了,我什么也没做。我相信VS或其他东西有一个奇怪的问题。我现在可以使用第 ItemTemplates 了。

标签: asp.net gridview datagridview updatecommand controlparameter


【解决方案1】:

要自行调试,您应该挂钩 SQL 数据源更新事件和 gridview 行更新事件以检查问题。

无论如何,在不了解您的数据库设计的情况下,我的猜测是您缺少更新参数上的类型。试试这样的:

<UpdateParameters>
  <asp:Parameter Name="Name" Type="String" />
  <asp:Parameter Name="Id" Type="Int64" />
</UpdateParameters>

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-10-03
    • 1970-01-01
    • 2010-12-11
    • 1970-01-01
    • 1970-01-01
    • 2010-11-26
    • 2012-07-12
    • 1970-01-01
    相关资源
    最近更新 更多