#662 - 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();
}


Approfondimenti
Commenti

Esprimi il tuo giudizio su questo script:

Per procedere devi essere autenticato.

darkox scrive:
#662 - Aggiungere una funzione di cancellazione ad un datagrid

ma per intercettare la riga da cancellare pensavo si facesse cosi:string id = datagrid.DataKeys[e.Item.ItemIndex]evidentemente mi sfugge qualcosaciao
mercoledì 12 gennaio 2005 | 3 risposte

Aggiungi un nuovo commento »»»
Per inserire un commento, devi registrarti alla nostra community.