Статистика

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

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

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

Метод 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.

Так что же такое XAML?

я начал свое изложение с

Большинство пользовательских интерфейсов WinFx будут, скорее всего, программироваться с помощью XAML. Я начал свое изложение с объектов и программного кода, чтобы подчеркнуть тот факт, что объекты, с которыми вы имеете дело в WinFx, — это просто новый набор элементов управления и классов из новой группы именных пространств, дополняющий существующую инфраструктуру. NET Framework. Однако помимо объектов, поддерживающих новые возможности WinFx в плане пользовательских интерфейсов, вводится и новый язык для спецификации кода этих интерфейсов. XAML дает в руки программистам, пишущим UI для Windows, возможности декларативной разметки с использованием XML, которой уже многие годы пользуются разработчики Web-приложений и которая часто позволяет проще специфицировать расположение и свойства элементов UI. Теоретически никому никогда не придется непосредственно редактировать XAML или какую-то другую форму кода XML. Инструментальные средства должны скрывать XML, позволяя вам манипулировать объектами в конструкторе более простыми способами, а в качестве результата этих манипуляций должен генерироваться соответствующий код XML. Можно надеяться, что к моменту выхода WinFx на рынок такие инструменты будут и в Visual Studio.

Но пока вам придется кодировать XAML вручную при помощи текстового редактора. В Visual Studio 2005 имеется, правда, привязанная к схеме поддержка IntelliSence в редакторе XML, которая может подсказывать вам допустимые элементы и атрибуты в зависимости от того, в каком месте дерева элементов XAML вы находитесь. Но все равно вы пишете XML вручную, что оставляет желать много лучшего.

В качестве примера я воссоздам пример DataBindinglOl, который показан на рис. Б.2 — окно с полем списка заказчиков и два текстовых поля, привязанных к одной коллекции, отображающих имя заказчика и телефонный номер из текущей записи, — но реализую приложение, используя смесь XAML и программного кода.