Создание команд SqlCommand

Приветствую всех, сегодня рассмотрим примеры создания команд и их использования.

SqlCommand – объект подключаемой части технологии ADO.NET, позволяющий выполнять инструкции T-SQL над источником данных. Для правильной работы объекту SqlCommand нужно предоставить подключение к источнику данных(экземпляр класса SqlConnection)

Способы создания объекта SqlCommand:

1) Использование конструктора по умолчанию

2) Использование метода CreateCommand() объекта SqlConnection

3) Использование перегрузки конструктора с двумя параметрами

Важно! Независимо от способа создания объекта SqlCommand, он должен получить экземпляр SqlConnection.

После создания объекта SqlCommand можно выполнять T-SQL инструкции над источником данных, для чего объект SqlCommand имеет ряд методов, позволяющих выполнять разные типы инструкций.

Методы объекта SqlCommand для выполнения команд:

  • ExecuteNonQuery() – этот метод предназначен для выполнения команд, не возвращающих значения. Такие команды могут выполнять следующие инструкции T-SQL: INSERT, DELETE, ALTER, DROP, CREATE.
  • ExecuteScalar() – этот метод предназначен для выполнения команд, возвращающих скалярные значения.
  • EcecuteReader() – этот метод предназначен для выполнения команд, возвращающих данные в табличном представлении(SELECT).

Объект DataReader представляет собой аналог пожарного курсора только для чтения, позволяющий просматривать табличные данные, которые возвращает команда. Получить объект DataReader можно с помощью метода ExecuteReader() объекта Command

Важно! С помощью объекта DataReader можно просматривать толькоодну строку в один момент времени и только в одномнаправлении.

SqlDataReader имеет ряд методов, свойств и индексаторов для получения информации, пришедшей от источника данных Ниже приведены некоторые из них.

Read() – этот метод возвращает значение true или false в зависимости от того, достигнут ли конец набора строк и при каждом его вызове перемещается к следующей строке.
FieldCount – свойство, позволяющее получить количество полей у строк, пришедших от источника.
GetName(int index) – метод, позволяющий получить имя поля по индексу Для получения значений отдельных полей строк SqldataReader имеет две перегрузки индексатора с целочисленным индексом и строковым, а так же строготипизированные методы Get<FieldType>(int index) и GetFieldValue<T>(int index)

Асинхронное выполнение команд

При создании UI приложений, использующих объект SqlCommand выполнение команд следует производить асинхронно во избежание блокировки пользовательского интерфейса. Специально для этого объект Command имеет методы асинхронного выполнения команд. Все методы для асинхронного выполнения команд имеют префикс Async.

Пример использования асинхронного выполнения команд над базой данных

При создании SqlCommand свойству CommandText можно присвоить сразу несколько операторов T-SQL.

При использовании объекта DataReader для такой команды после просмотра данных первого набора строк нужно перейти к следующему набору с помощью метода NextResult() объекта DataReader.

Пример:

ТРАНЗАКЦИИ

Транзакцией называется выполнение последовательности команд (SQL- конструкций) в базе данных, которая либо фиксируется при успешной реализации каждой команды, либо отменяется при неудачном выполнении хотя бы одной команды.

Откат транзакции — это действие, обеспечивающее аннулирование всех изменений данных, которые были сделаны в теле текущей незавершенной транзакции.

При выполнении транзакций несколькими пользователями одной базы данных могут возникать следующие проблемы:

  • Dirty reads
  • Non-repeatable reads
  • Phantom reads

Dirty reads – «грязное» чтение. Первый пользователь начинает транзакцию, изменяющую данные. В это время другой пользователь (или создаваемая им транзакция) извлекает частично измененные данные, которые не являются корректными.

Non-repeatable reads — неповторяемое чтение. Первый пользователь начинает транзакцию, изменяющую данные. В это время другой пользователь начинает и завершает другую транзакцию. Первый пользователь при повторном чтении данных (например, если в его транзакцию входит несколько инструкций SELECT) получает другой набор записей.

Phantom reads — чтение фантомов. Первый пользователь начинает транзакцию, выбирающую данные из таблицы. В это время другой пользователь начинает и завершает транзакцию, вставляющую или удаляющую записи. Первый пользователь получит другой набор данных, содержащий фантомы — удаленные или измененные строки.

Важно! От неповторяющегося чтения оно отличается тем, что результат повторного обращения к данным изменился не из-за изменения/удаления самих этих данных, а из-за появления новых (фантомных) данных.

Для решения этих проблем разработаны четыре уровня изоляции транзакции в SQL:

  • Read uncommitted.
  • Read committed.
  • Repeatable read.
  • Serializable.

Read uncommitted. Транзакция может считывать данные, с которыми работают другие транзакции. Применение этого уровня изоляции может привести ко всем перечисленным проблемам.

Read committed. Транзакция не может считывать данные, с которыми работают другие транзакции. Применение этого уровня изоляции исключает проблему «грязного» чтения.

Repeatable read. Транзакция не может считывать данные, с которыми работают другие транзакции. Другие транзакции также не могут считывать данные, с которыми работает эта транзакция. Применение этого уровня изоляции исключает все проблемы, кроме чтения фантомов.

Serializable. Транзакция полностью изолирована от других транзакций. Применение этого уровня изоляции полностью исключает все проблемы.

 

CommandText – текст запроса. Метод ExecuteNonQuery применяется для выполнения запросов, невозвращающих данные, таких как UPDATE, INSERT и DELETE – они вносят изменения в таблицу базы данных, не возвращая ничего назад в результате выполнения.

Пример команд, возвращающих скалярные значения:

Пример выполнение команд вставки и удаления:

Пример выполнение команд, возвращающих данные в табличном представлении:

 

 

 

Обновлено: 06.08.2018 — 15:53

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Этот сайт использует Akismet для борьбы со спамом. Узнайте, как обрабатываются ваши данные комментариев.