Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/32.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
asp.net GridView中TemplateField中的UpdateCommand问题_Asp.net_Gridview_Datagridview_Updatecommand_Controlparameter - Fatal编程技术网

asp.net GridView中TemplateField中的UpdateCommand问题

asp.net GridView中TemplateField中的UpdateCommand问题,asp.net,gridview,datagridview,updatecommand,controlparameter,Asp.net,Gridview,Datagridview,Updatecommand,Controlparameter,我有以下表格: <asp:GridView DataSourceID="accountsDataSource" DataKeyNames="Id" ShowEditButton="true" ...> <asp:TemplateField HeaderText="Name"> <ItemTemplate> <asp:Hyperlink ID="lnkGridEditEntry" runat="server" Text='<

我有以下表格:

<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”而崩溃。我认为这是因为在呈现网格时,template字段中的文本框会获得不同的ID(比如ct100$txtGridAccountName$…),显然找不到它

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

如果我删除模板字段并在工作时显示名称


非常感谢您为解决此问题提供的任何帮助。

要自己调试此问题,您应该连接到SQL数据源更新事件和gridview行更新事件以检查问题

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

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


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