0

我有一个 gridview,其中包含删除和编辑行的按钮。我有gridview的这个html代码:

<asp:GridView ID="gvList" runat="server">
<Columns>

<asp:TemplateField HeaderText="Actions" HeaderStyle-ForeColor="black" HeaderStyle-Font-Bold="true">
<ItemTemplate>
<asp:Button ID="btnedit" runat="server" Text="Edit" />
<asp:Button CommandArgument='<%# Eval("cUserName")%>' ID="btnDelete" OnClick="DeleteRow" runat="server" Text="Delete" />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>

我需要使用命令参数激活删除和编辑按钮。我对 commandargument 没有完全了解,我想还有其他方法可以更好地做到这一点。无论如何,我在vb服务器端有这个代码:

Public Function DelRow() As DataTable

Dim Btn As ImageButton = CType(sender, ImageButton)


    Dim Query As String = "Delete FROM Intranet.dbo.Gn_ISCoordinators where cUserName=" & Btn.CommandArgument
    Dim dt As DataTable = New DataTable()
'
'I need to complete this
'...
'
End Using
End Function

另外,我想知道是否btnAdd.CommandArgument正确。Ps:我在sender下的CType(sender,ImageButton)有错误。

4

1 回答 1

1

asp:Button应该使用以下行进行转换:

Dim Btn As ImageButton = CType(sender, Button)

Button不如ImageButton。_

其次,您将从中获取用户名,Btn.CommandArgumentCommandArgument与 SQL 查询连接并不是一个好主意。如果不是存储过程或某些 ORM 框架,至少尝试使用带参数的查询。使用以下命令连接数据库并执行查询:

Using con As SqlConnection = New SqlConnection(<CONNECTION_STRING>)
    con.Open()
    Dim sql As String = "Delete FROM Intranet.dbo.Gn_ISCoordinators where" & _
                      " cUserName= @UserName"

    Dim cmd As SqlCommand = New SqlCommand(sql, con)
    cmd.Parameters.Add(New SqlParameter("@UserName", Btn.CommandArgument))

    cmd.ExecuteNonQuery() 
    con.Close()
End Using

PS:- 我的 VB.Net 充其量是质朴的。另外请注意在对数据库执行代码时可能会出现异常。所以请使用异常处理等。

于 2013-03-13T05:57:21.693 回答