5. Общее представление об интерфейсах привязки данных

Организация виртуального режима

создайте сетку и определите в

Ниже описывается последовательность действий для организации привязки данных в виртуальном режиме. Создайте сетку и определите в ней столбцы, которые будут работать в виртуальном режиме. Переведите сетку в виртуальный режим, установив ее свойство VirtualMode Равным True. Ели вы не применяете привязку данных, добавьте к сетке нужное число строк, чтобы обеспечить поддержку прокрутки. Самым простым и быстрым способом сделать это является создание единственной строки-прототипа, любое количество копий которой можно добавить затем к сетке методом AddCopies Коллекции Rows. В данный момент не нужно беспокоиться о содержимом ячеек, так как вы собираетесь предоставлять его динамически в обработчике события, в процессе отображения сетки. Последним шагом является подключение обработчика для события CellValueNeeded Сетки. Это событие возбуждается только в том случае, если сетка функционирует в виртуальном режиме, и будет запускаться для каждой видимой в настоящий момент ячейки несвязанного столбца либо при первом ее отображении, либо при прокрутке сетки показывает простое приложение Windows Forms, демонстрирующее использование виртуального режима. Объект DataGridView Был помещен на форму в конструкторе и назван M Grid; Также на форму была добавлена кнопка с именем M GetVisitedCountButton Для проверки того, сколько строк появлялось в сетке в результате прокрутки. Конструктор формы, как обычно, начинается с вызова InitializeCom — Ponent, Чтобы исполнить код, генерированный в результате операций перетаскивания и установок в окне Properties. В данном примере этот код просто объявляет и создает на форме сетку и кнопку. Затем код конструктора назначает посредством неявного делегирования два обработчика событий. Для виртуального режима важен первый из обработчиков — для события CellValueNeeded. Как уже упоминалось, это событие возбуждается только в виртуальном режиме сетки и запускается для каждой ячейки несвязанного столбца, видимой в сетке в любой данный момент. Когда пользователь прокручивает сетку, это событие вновь запускается для каждой из ячеек, появляющихся в процессе прокрутки. Конструктор также назначает обработчик для события щелчка на кнопке, который позволяет вам посмотреть, для скольких строк в действительности вызывался обработчик события CellValueNeeded

Добавление экземпляров столбчатой диаграммы в контейнер

этот метод показан в листинге

Метод AddBarChartControl Получает дескрипторы свойства для для всех столбцов или свойств в соответствующем элементе данных, определяет, является ли поле численным типом, исходя из свойства PropertyType Его дескриптора, а затем извлекает имя и значение поля и добавляет соответствующую пару ChartPair К свойству Data Столбчатой диаграммы. Этот метод показан в листинге 8.10.

Метод AddBarChartControl Создает экземпляр BarChartControl, Инициализирует его размер и положение, после чего добавляет его к коллекции Controls Инкапсулирующего пользовательского элемента управления. Затем он проходит в цикле по всем свойствам переданного ему элемента данных, и если это численный тип или строка, которую можно преобразовать в численный тип, к коллекции Data Столбчатой диаграммы добавляется соответствующая пара ChartPair. Обратите внимание на применение нового метода TryParse Класса Double. Каждый примитивный класс в. NET имеет метод Parse, Существующий начиная с версии 1.0 библиотеки Framework. Проблема с методом Parse Состоит в том, что если ему не удастся преобразовать переданную строку, он выбросит исключение, а это очень дорогостоящее действие, которое может сдерживать производительность приложения, если производится достаточно часто. Поэтому В Framewok версии 2.0 к каждому примитивному типу добавлен метод TryParse, Который позволяет вам попытаться преобразовать строковое значение в значение примитивного типа, не выбрасывая исключения. Если преобразование удается, метод возвращает булево значение True, И вы можете использовать значение из переданного вами второго параметра метода. Как вы можете видеть, не так уж много кода требуется для того, чтобы самостоятельно обрабатывать привязку данных без источника привязки, выполняя простую итерацию по источнику данных и отображая данные, однако в этом коде отсутствует еще очень многое, с том числе поддержка сортировки, фильтрации, редактирования, добавления новых строк и т. п., что делает за вас источник привязки. Метод ListBindingHelper.GetList Обеспечивает аспекты первоначального исследования и раскрытия при отыскании соответствующего списка в источнике данных. Для осуществления всего прочего потребуется работать с рядом других типов интерфейсов. Для этого вы обычно захотите воспользоваться поддержкой источника данных.

Большинство элементов управления предназначено для привязки к разнообразным типам коллекций и элементов данных

для этого можно применить метод

Поскольку большинство элементов управления предназначено для привязки к разнообразным типам коллекций и элементов данных, обычно приходится прибегать к динамически типизированному разрешению элемента, к которому вы пытаетесь привязаться. Для этого можно применить метод DataBinder.Eval: Здесь, чтобы попытаться найти на текущем элементе в привязанной коллекции данных свойство или поле CustomeriD и вернуть его значение, используется рефлексия.

ASP. NET 2.0 поддерживает упрощенный синтаксис DataBinder.Eval, Использующий метод Eval. Следующее выражение: дает тот же результат, что и более длинная конструкция с методом Data — Binder.Eval. В. NET 2.0 имеется также новый метод Bind, Который целесообразно использовать вместо Eval Для выражений, применяемых к коллекциям, поддерживающим обновление при обратных отсылках. Если вы собираетесь разрешить пользователю редактировать данные в элементе управления, и этот элемент привязан к источнику данных, поддерживающему долговременные обновления, то, если имеет место отсылка с отредактированными данными, метод Bind Вызовет для привязанного источника метод обновления. Такого рода автоматическое обновление поддерживается, в частности, классами GridView, DetailsView И FormView. Следует пользоваться методом Bind Вместо Eval Во всех случаях, когда вы устанавливаете свойства в шаблоне для одного из новых привязанных элементов управления, и когда вы устанавливаете с помощью свойства DataSourcelD Источник данных, поддерживающий обновление при отсылках.

Элементы управления PictureBox

все что для этого нужно

Небольшой, но мощный и удобный элемент управления PictureBox Можно использовать, когда вам нужно поместить на форме изображение. Все, что для этого нужно сделать — это конструировать объект класса Bitmap Из пространства имен System.Drawing И присвоить его свойству Image Элемента управления PictureBox. Последний имеет также свойство SizeMode, Которое можно устанавливать равным Normal, AutoSize, Center — Image, Stretchlmage Или Zoom. В зависимости от значения, которое вы установили для SizeMode, Элемент управления PictureBox Будет автоматически управлять изменением размера изображения, когда форма, на которой он находится, будет перерисовываться или изменять свой размер. Элемент управления DataGrid Был оплотом табличного представления данных в. NET 1.x. Он позволяет вам привязывать наборы данных, таблицы и коллекции данных к сетке для отображения в табличной форме. Элемент управления может обнаруживать отношения между несколькими таблицами в наборе данных и предусматривает схему навигации между родительскими и дочерними строками данных. Он позволяет легко сортировать строки по выбранному столбцу и настраивать представление столбцов и всей таблице посредством классов стилей. Однако поскольку у DataGrid Было много проблем как в плане удобства применения, так и в плане настройки, в. NET 2.0 был введен элемент управления DataGridview. Этот элемент управления стал преемником DataGrid В качестве основного элемента управления для табличного представления данных в новых приложениях. Если вы обновляете существующие приложения, которые используют DataGrid, Вам не обязательно переходить на DataGridview. Ваш существующий код с DataGrid Будет продолжать работать, как прежде, но я не рекомендую применять элемент управления DataGrid В каком-либо новом коде приложений. NET 2.0.

Работа с транзакциями

это можно сделать внутри sql

Иногда вам требуется возможность исполнять несколько команд в пределах области действия единственной транзакции с базой данных, чтобы в случае, когда любая из команд терпит неудачу, терпели неудачу они все, и никаких изменений в базе данных не производилось бы. Это можно сделать внутри SQL Server и других баз данных, начиная транзакцию внутри сохраняемой процедуры и фиксируя либо откатывая ее в зависимости от результатов запросов, инкапсулированных внутри процедуры. Однако иногда вам нужно контролировать транзакцию из вашего кода ADO. NET, заключив в одну транзакцию исполнение нескольких команд. Сделать это довольно просто. Вы можете использовать класс SqlTrans — Action в сочетании с соединением, чтобы управлять транзакцией из своего кода доступа к данным. Допустим, например, что вы хотите написать код, который сначала проверял бы, существует ли строка, и если существует, то делал какие-то модификации этой строки. Давайте также допустим, что вам нужно это сделать посредством двух явных текстовых SQL-запросов из вашего управляемого кода. Вы хотите написать непробиваемый код, поэтому должны быть уверены, что строка, которая будет подвергаться обновлению, не будет модифицирована или удалена другим клиентом или запросом в промежутке между моментом, когда вы проверяете ее существование, и моментом, когда вы ее обновляете. Использование транзакции с соответствующим уровнем изоляции отлично подойдет для такого сценария. Взгляните на код в листинге Г.9.

Здесь следует обсудить несколько моментов. Первый — как создать и применить транзакцию. Код создает соединение и объекты команд, как вы уже видели раньше. Транзакция создается вызовом BeginTransaction Для соединения с необязательной спецификацией уровня изоляции. Уровень изоляции по умолчанию — ReadCommitted, Но чтобы гарантировать, что никто не сможет модифицировать запись после того, как она была прочитана оператором SELECT, вам нужен ReadRe — Peatable.