Удаление DataRowDataRow Deletion

Существует два способа, можно использовать для удаления DataRow объекта из DataTable объект: удалить метод DataRowCollection объекта и Delete метод DataRowобъекта.There are two methods you can use to delete a DataRow object from a DataTable object: the Remove method of the DataRowCollection object, and the Delete method of the DataRow object. Тогда как Remove метод удаления DataRow из DataRowCollection, Delete метод только помечает строку для удаления.Whereas the Remove method deletes a DataRow from the DataRowCollection, the Delete method only marks the row for deletion. Фактическое удаление происходит, когда приложение вызывает AcceptChanges метод.The actual removal occurs when the application calls the AcceptChanges method. Использование метода Delete позволяет программно проверять, какие строки помечены для удаления, перед их фактическим удалением.By using Delete, you can programmatically check which rows are marked for deletion before actually removing them. Когда строка отмечена для удаления, ее свойство RowState имеет значение Delete.When a row is marked for deletion, its RowState property is set to Delete.

Ни Delete, ни Remove не должны вызываться в цикле foreach во время итерации по объекту DataRowCollection.Neither Delete nor Remove should be called in a foreach loop while iterating through a DataRowCollection object. Ни Delete, ни Remove не изменяет состояние коллекции.Delete nor Remove modify the state of the collection.

При использовании DataSet или DataTable в сочетании с DataAdapter и реляционного источника данных, используйте удалить метод DataRow для удаления строки.When using a DataSet or DataTable in conjunction with a DataAdapter and a relational data source, use the Delete method of the DataRow to remove the row. Удалить метод помечает строку как Deleted в набора данных или DataTable , но не удаляет ее.The Delete method marks the row as Deleted in the DataSet or DataTable but does not remove it. Вместо этого, когда DataAdapter обнаруживает строку, помеченную как Deleted, он выполняет его DeleteCommand метод для удаления строки в источнике данных.Instead, when the DataAdapter encounters a row marked as Deleted, it executes its DeleteCommand method to delete the row at the data source. Строки могут затем быть окончательно удалить с помощью AcceptChanges метод.The row can then be permanently removed using the AcceptChanges method. Если вы используете удалить для удаления строки, строка удаляется из таблицы, но DataAdapter не приведет к удалению строки в источнике данных.If you use Remove to delete the row, the row is removed entirely from the table, but the DataAdapter will not delete the row at the data source.

Удалить метод DataRowCollection принимает DataRow в качестве аргумента и удаляет его из коллекции, как показано в следующем примере.The Remove method of the DataRowCollection takes a DataRow as an argument and removes it from the collection, as shown in the following example.

workTable.Rows.Remove(workRow)  
workTable.Rows.Remove(workRow);  

Напротив, следующий пример демонстрирует вызов удалить метод DataRow для изменения его RowState для Deleted .In contrast, the following example demonstrates how to call the Delete method on a DataRow to change its RowState to Deleted.

workRow.Delete  
workRow.Delete();  

Если строка помечена для удаления и вызывается AcceptChanges метод DataTable объект, строка удаляется из DataTable.If a row is marked for deletion and you call the AcceptChanges method of the DataTable object, the row is removed from the DataTable. Напротив, при вызове метода RejectChanges, RowState строки возвращается к до помечается как Deleted.In contrast, if you call RejectChanges, the RowState of the row reverts to what it was before being marked as Deleted.

Примечание

Если RowState из DataRowAdded, означающее, что она недавно была добавлена в таблицу и затем она помечается как Deleted, это удаляется из таблицы.If the RowState of a DataRow is Added, meaning it has just been added to the table, and it is then marked as Deleted, it is removed from the table.

См. такжеSee also