Книга: ЯЗЫК ПРОГРАММИРОВАНИЯ С# 2005 И ПЛАТФОРМА .NET 2.0. 3-е издание
Асинхронный доступ к данным в .NET 2.0
Асинхронный доступ к данным в .NET 2.0
В .NET 2.0 поставщик данных SQL (представленный пространством имен System.Data.SqlClient) усовершенствован с тем, чтобы он мог поддерживать асинхронное взаимодействие с базой данных, используя следующие новые члены SqlCommand.
• BeginExecuteReader()/EndExecuteReader()
• BeginExecuteNonQuery()/EndExecuteNonQuery()
• BeginExecuteXmlReader()/EndExecuteXmlReader()
С учетом материала, представленного в главе 14, названия пар этих методов можно считать "триумфом" соглашения о присвоении имен. Напомним, что в шаблоне асинхронного делегата .NET используется метод "begin" для выполнения задач во вторичном потоке, тогда как метод "end" может использоваться для получения результата асинхронного вызова с помощью членов IAsyncResult и необязательного делегата AsyncCallback. Поскольку работа с асинхронными командами моделируется по образцу делегата, простого примера в этом случае должно быть достаточно (но не забудьте снова заглянуть в главу 14, чтобы освежить в памяти подробности, касающиеся использования делегатов асинхронного вызова).
Предположим, что нам нужно выбрать записи из таблицы Inventory во вторичном потоке выполнения, используя объект чтения данных. Вот полный текст соответствующего метода Main() с последующим анализом.
static void Main(string[] args) {
Console.WriteLine ("***** Забавы с ASNYC DataReader *****n");
// Создание открытого соединения в асинхронном режиме.
SqlConnection cn = new SqlConnection();
cn.ConnectionString = "uid=sa;pwd=;Initial Catalog=Cars;" +
"Asynchronous Processing=true;Data Source=(local)";
cn.Open();
// Создание объекта SQL-команды, ожидающего около 2 с.
string strSQL = "WaitFor Delay '00:00:02';Select * From Inventory";
SqlCommand myCommand = new SqlCommand(strSQL, cn);
// Выполнение чтения во втором потоке.
IAsyncResult itfAsynch;
itfAsynch = myCornmand.BeginExecuteReader(CommandBehavior.CloseConnection);
// Выполнение действий во время работы другого потока.
while (!itfAsynch.IsCompleted) {
Console.WriteLine("Работа в главном потоке…");
Thread.Sleep(1000);
}
Console.WriteLine();
// Все готово! Выполнение цикла по результатам
// с помощью объекта чтения данных.
SqlDataReader myDataReader = myCommand.EndExecuteReader(itfAsynch);
while (myDataReader.Read()) {
Console.WriteLine("-› Марка – {0) название – {1}, цвет – {2}.",
myDataReader["Make"].ToString.Trim(),
myDataReader["PetName"].ToString().Trim(),
myDataReader["Color"].ToString().Trim());
}
myDataReader.Close();
}
Первый интересным моментом здесь является то, что вы должны разрешить асинхронное взаимодействие с помощью нового сегмента Asynchronous Processing в строке соединения. Также отметьте, что в текст объекта команды SqlCommand был добавлен сегмент WaitFor Delay для имитации длительного взаимодействия с базой данных.
Кроме этого обратите внимание на то, что вызов BeginExecuteDataReader() возвращает ожидаемый IAsyncResult-совместимый тип, который используется для синхронизации потока вызова (с помощью свойства IsCompleted), а также для получения SqlDataReader по завершении выполнения запроса.
Исходный код. Проект AsyncCmdObject размещен в подкаталоге, соответствующем главе22.
- Высокоуровневое определение ADO.NET
- Поставщики данных ADO.NET
- Дополнительные пространства имен ADO.NET
- Типы System.Data
- Интерфейсы и абстрактные поставщики данных
- Файлы конфигурации и гибкость приложений
- Модель источника поставщика данных .NET 2.0
- Элемент ‹connectionStrings›
- Установка базы данных Cars
- Связный уровень ADO.NET
- Работа с объектами чтения данных
- Изменение содержимого таблиц с помощью объектов команд
- Работа с объектами параметризованных команд
- Выполнение хранимых процедур с помощью DbCommand
- Асинхронный доступ к данным в .NET 2.0
- Несвязный уровень ADO.NET
- Роль DataSet
- Работа с DataColumn
- Работа с DataRow
- Работа с DataTable
- Сохранение DataSet (и DataTable) в формате XML
- Привязка DataTable к интерфейсу пользователя
- Работа с типом DataView
- Работа с адаптерами данных
- Обновление базы данных с помощью объекта адаптера данных
- Генерирование SQL-команд с помощью типов построителя команд
- Объекты DataSet с множеством таблиц и объекты DataRelation
- Возможности мастеров данных
- Резюме
- Доступ к данным с помощью объекта DataTable
- Поставщики данных ADO.NET
- Что делать, если при установке принтера появляется сообщение Невозможно завершение операции. Подсистема печати недоступн...
- Улучшенный протокол локальных соединений (XNET)
- Асинхронный сервер и отмена выполняющихся запросов
- 9.4. Права доступа к squid
- Chapter 16. Commercial products based on Linux, iptables and netfilter
- Глава 29 Доступ к канальному уровню
- NETMAP target
- 10.5. Транзакции и пути доступа меню
- Internet Service Providers who use assigned IP addresses
- Настройка доступа пользователей к рабочей книге