Чтение онлайн

ЖАНРЫ

ЯЗЫК ПРОГРАММИРОВАНИЯ С# 2005 И ПЛАТФОРМА .NET 2.0. 3-е издание

Троелсен Эндрю

Шрифт:

Чтобы увидеть результаты в нисходящем порядке, вызовите Select, как показано ниже.

// Возвращает результаты в порядке убывания.

makes = inventoryTable.Select(filterStr, "PetName DESC");

Вообще говоря, строка сортировки должна содержать имя столбца, за которым следует "ASC" (обозначающее порядок по возрастанию, что является значением, принимаемым по умолчанию) или "DESC" (обозначающее порядок по убыванию). При необходимости можно указать несколько столбцов, разделив их запятыми. Наконец, следует понимать, что в строке фильтра можно использовать любое число операций

отношения. Например, если требуется найти все автомобили с номерами, большими 5, то вот как должна выглядеть вспомогательная функция, которая сделает это.

private void ShowCarsWithIdLessThanFive {

 // Вывод названий машин с номерами, большими 5.

 DataRow[] properIDs;

 string newFilterStr = "ID › 5";

 properIDs = inventoryTable.Select(newFilterStr);

 string strIDs = null;

 for (int i = 0; i ‹ properIDs.Length; i++) {

DataRow temp = properIDs[i];

strIDs += temp["PetName"] + " is ID " + temp["ID"] + "\n";

 }

 MessageBox.Show(strIDs, "Названий машин с ID › 5");

}

Обновление строк

Еще одной операцией, которую вы должны освоить, является изменение значений существующей в DataTable строки. С этой целью можно, например, сначала c помощью метода Select получить строку, соответствующую имеющемуся критерию фильтра. Имея соответствующий объект DataRow, вы можете соответствующим образом его изменить. Предположим, что в форме есть кнопка (тип Button). при щелчке на которой выполняется поиск тех строк в объекте DataTable, для которых Make равно BMW. Идентифицировав эти элементы, вы изменяете значение Make с BMW на Colt.

// Поиск строк для редактирования с помощью фильтра.

private void btnChangeBeemersToColts_Click(object sender, EventArgs e) {

 // Проверка вменяемости пользователя.

 if (DialogResult.Yes == MessageBox.Show("Вы уверены?? BMW намного лучше, чем Colt!", "Подтвердите свой выбор!", MessageBoxButtons.YesNo)) {

// Построение фильтра.

string filterStr = "Make='BMW'";

string strMake = null;

// Поиск строк, соответствующих критериям фильтра.

DataRow[] makes = inventoryTable.Select(filterStr);

// Замена бумеров на кольты!

for (int i = 0; i ‹ makes.Length; i++) {

DataRow temp = makes[i];

strMake += temp["Make"] = "Colt";

makes[i] = temp;

}

 }

}

Класс DataRow предлагает методы BeginEdit, EndEdit и CancelEdit, которые позволяют редактировать содержимое строки, временно приостанавливая все заданные условия проверки ввода. При использовании предложенной выше программной логики строка будет проверяться с каждым новым присваиванием. (И если вы задали обработку каких-то событий DataRow, они тоже будут генерироваться с каждой модификацией.) При вызове BeginEdit

для DataRow строка переводится в режим редактирования. Вы получаете возможность внести любые необходимые вам изменения, чтобы затем вызывать EndEdit и зафиксировать эти изменения или CancelEdit и выполнить откат к оригинальной версии данных, например:

private void UpdateSomeRow {

 // Предполагается, что строка для редактирования уже получена.

 // Выполняется перевод этой строки в режим редактирования.

 rowToUpdate.BeginEdit;

 // Отправка строки вспомогательной функции, возвращающей Boolean.

 if (ChangeValuesForThisRow(rowToUpdate)) rowToUpdate.EndEdit; // OK!

 else rowTaUpdate.CancelEdit; // Забудьте об этом.

}

Вы, конечно, можете вызывать эти методы для данного DataRow и вручную, но они вызываются автоматически при редактировании элемента DataGridView, связанного с DataTable. Например, при выборе строки в DataGridView эта строка автоматически переводится в режим редактирования. А при перемещении фокуса ввода в новую строку автоматически вызывается EndEdit.

Работа с типом DataView

В терминах базы данных представление - это показ набора данных таблицы (или множества таблиц) в определенном стиле. Например, с помощью Microsoft SQL Server на базе таблицы Inventory можно создать представление, которое возвратит новую таблицу, содержащую автомобили только заданного цвета. В ADO.NET тип DataView позволяет программно извлечь подмножество данных из DataTable и разместить их в отдельном объекте. Одним из важных преимуществ создания множества представлений одной и той же таблицы: является то, что вы можете связать эти представления с различными элементами графического интерфейса (такими, как DataGridView). К примеру, один элемент DataGridView можно связать с объектом DataView, показывающим все машины из таблицы Inventory, в то время как другой элемент будет настроен на отображение только зеленых автомобилей.

Для иллюстрации добавите к текущему графическому интерфейсу еще один тип DataGridView, назвав его dataGridColtsView и сопроводив поясняющим элементом Label. Затем определите член-переменную coltsOnlyView типа DataView.

public partial class MainForm: Form {

 // Представление для DataTable.

 DataView coltsOnlyView;

 // Отображение только красных кольтов.

 …

}

Теперь создайте новую вспомогательную функцию с именем CreateDataView и вызовите этот метод в конструкторе формы, заданном по умолчанию, сразу же после того, как будет создан тип DataTable:

public MainForm {

 …

 // Создание таблицы данных.

 CreateDataTable;

 // Создание представления.

 CreateDataView;

}

Ниже показана реализация этой новой вспомогательной функции. Обратите внимание на то, что конструктору DataView передается тип DataTable, который будет использоваться для построения пользовательского набора cтрок данных.

Поделиться с друзьями: