// Предполагается, что строка для редактирования уже получена.
// Выполняется перевод этой строки в режим редактирования.
rowToUpdate.BeginEdit;
// Отправка строки вспомогательной функции, возвращающей Boolean.
if (ChangeValuesForThisRow(rowToUpdate)) rowToUpdate.EndEdit; // OK!
else rowTaUpdate.CancelEdit; // Забудьте об этом.
}
Вы, конечно, можете вызывать эти методы для данного DataRow и вручную, но они вызываются автоматически при редактировании элемента DataGridView, связанного с DataTable. Например, при выборе строки в DataGridView эта строка автоматически переводится в режим редактирования. А при перемещении фокуса ввода в новую строку автоматически вызывается EndEdit.
В терминах базы данных
Для иллюстрации добавите к текущему графическому интерфейсу еще один тип DataGridView, назвав его dataGridColtsView и сопроводив поясняющим элементом Label. Затем определите член-переменную coltsOnlyView типа DataView.
public partial class MainForm: Form {
// Представление для DataTable.
DataView coltsOnlyView;
// Отображение только красных кольтов.
…
}
Теперь создайте новую вспомогательную функцию с именем CreateDataView и вызовите этот метод в конструкторе формы, заданном по умолчанию, сразу же после того, как будет создан тип DataTable:
public MainForm {
…
// Создание таблицы данных.
CreateDataTable;
// Создание представления.
CreateDataView;
}
Ниже показана реализация этой новой вспомогательной функции. Обратите внимание на то, что конструктору DataView передается тип DataTable, который будет использоваться для построения пользовательского набора cтрок данных.
private void CreateDataView {
// Установка таблицы для представления.
coltsOnlyView = new DataView(inventoryTable);
// Настройка представления с помощью фильтра.
coltsOnlyView.RowFilter = "Make = 'Colt'";
// Привязка к элементу управления,
dataGridColtsView.DataSource = coltsOnlyView;
}
Как видите, класс DataView предлагает свойство RowFilter, содержащее строку критериев фильтрации, используемую для поиска соответствующих строк. После получения объекта представления соответственно устанавливается свойство DataSource элемента управления. На рис. 22.17 показано окно готового приложения.
Рис. 22.17. Представление отфильтрованных данных
Исходный код. Проект CarDafaTableViewer размещен в подкаталоге, соответствующем главе 22.
Теперь, когда вы знаете возможности использования типов DataSet ADO.NET, обратим внимание на адаптеры данных. Напомним, что объекты адаптера данных используются для "наполнения" DataSet объектами DataTable и возврата измененных объектов DataTable базе данных для обработки. Описания основных членов базового класса DbDataAdapter приведены в табл. 22.15.
Таблица 22.15. Основные члены класса DbDataAdapter