Wie Sie wiederverwenden SqlCommand-parameter durch jede iteration?

Will ich implementieren Sie ein einfaches löschen-Knopf für meine Datenbank. Die Ereignis-Methode sieht ungefähr so aus:

private void btnDeleteUser_Click(object sender, EventArgs e)
{
    if (MessageBox.Show("Are you sure?", "delete users",MessageBoxButtons.OKCancel, MessageBoxIcon.Warning) == DialogResult.OK)
    {
        command = new SqlCommand();
        try
        {
            User.connection.Open();
            command.Connection = User.connection;
            command.CommandText = "DELETE FROM tbl_Users WHERE userID = @id";
            int flag;
            foreach (DataGridViewRow row in dgvUsers.SelectedRows)
            {
                int selectedIndex = row.Index;
                int rowUserID = int.Parse(dgvUsers[0,selectedIndex].Value.ToString());

                command.Parameters.AddWithValue("@id", rowUserID);
                flag = command.ExecuteNonQuery();
                if (flag == 1) { MessageBox.Show("Success!"); }

                dgvUsers.Rows.Remove(row);
            }
        }
        catch (SqlException ex)
        {
            MessageBox.Show(ex.Message, Application.ProductName, MessageBoxButtons.OK, MessageBoxIcon.Information);
        }
        finally
        {
            if (ConnectionState.Open.Equals(User.connection.State)) 
               User.connection.Close();
        }
    }
    else
    {
        return;
    }
}

aber ich bekomme diese Meldung:

Variable @id deklariert wurde. Variablennamen müssen eindeutig sein innerhalb
eine Abfrage, der batch oder die gespeicherte Prozedur.

Gibt es eine Möglichkeit zur Wiederverwendung dieser Variablen?

InformationsquelleAutor der Frage miller | 2012-08-23

Schreibe einen Kommentar