Aggiungere una funzione di cancellazione ad un DataGrid
Aggiungere un pulsante di eliminazione ad un datagrid rappresenta il giusto completamento alle possibilità offerte da questo control.
Si tratta per prima cosa di definire una ButtonColumn ed associare un relativo event handler:
<asp:datagrid id="dg" runat="server" OnDeleteCommand="Delete_Click"> <Columns> [altre colonne] <asp:ButtonColumn ButtonType="LinkButton" Text="Delete" CommandName="Delete" /> </Columns> </asp:datagrid>
A questo punto è sufficiente intercettare l'evento Delete_Click e costruire, attraverso una query parametrica, il comando che effettui la cancellazione:
public void Delete_Click(object sender, DataGridCommandEventArgs e) { string ID = e.Item.ItemIndex; string query = "DELETE FROM tabella WHERE ID = @ID"; // eseguo la query parametrica SqlConnection conn = new SqlConnection(connectionString); SqlCommand cmd = new SqlCommand(query, conn); cmd.Parameters.Add("@ID", dg.DataKeys[ID]); conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); // riazzero la selezione e rifaccio il binding dei dati dg.EditItemIndex = -1; BindGrid(); }







