15818

SQL Server 2005. Программирование на T-SQL

Лекция

Информатика, кибернетика и программирование

SQL Server 2005. Программирование на TSQL Программирование на TSQL Синтаксис и соглашения TSQL. Правила формирования идентификаторов Все объекты в SQL Server имеют имена идентификаторы. Примерами объектов являются таблицы представления хранимые процедуры и т.д. Идентификато

Русский

2013-06-18

78.5 KB

20 чел.

SQL Server 2005. Программирование на T-SQL

Программирование на T-SQL

 

Синтаксис и соглашения T-SQL. Правила формирования идентификаторов

Все объекты в SQL Server имеют имена (идентификаторы). Примерами объектов являются таблицы, представления, хранимые процедуры и т.д. Идентификаторы могут включать до 128 символов, в частности, буквы, символы _ @ $ # и цифры. Первый символ всегда должен быть буквенным. Для переменных и временных таблиц используются специальные схемы именования. Имя объекта не может содержать пробелов и совпадать с зарезервированным ключевым словом SQL Server, независимо от используемого регистра символов. Путем заключения идентификаторов в квадратные скобки, в именах объектов можно использовать запрещенные символы.

 Завершение инструкции. Стандарт ANSI SQL требует помещения в конце каждой инструкции точки с запятой. В то же время при программировании на языке T-SQL точка с запятой не обязательна.

 Комментарии
Язык T-SQL допускает использование комментариев двух стилей: ANCI и языка С. Первый из них начинается с двух дефисов и заканчивается в конце строки:

 -- Это однострочный комментарий стиля ANSI

 Также комментарии стиля ANSI могут вставляться в конце строки инструкции:

 SELECT CityName – извлекаемые столбцы FROM City – исходная таблица WHERE IdCity = 1; -- ограничение на строки

 Редактор SQL может применять и удалять комментарии во всех выделенных строках. Для этого нужно выбрать соответствующие команды в меню Правка или на панели инструментов .

 Комментарии стиля языка С начинаются с косой черты и звездочки (/*) и заканчиваются теми же символами в обратной последовательности. Этот тип комментариев лучше использовать для комментирования блоков строк, таких как заголовки или большие тестовые запросы.

 /*Пример
многострочного
комментария
*/

 Одним из главных достоинств комментариев стиля С является то, что многострочные запросы в них можно выполнять, даже не раскомментируя.

 Пакеты T-SQL

Запросом называют одну инструкцию T-SQL, а пакетом — их набор. Вся последовательность инструкций пакета отправляется серверу из клиентских приложений как одна цельная единица.
SQL Server рассматривает весь пакет как рабочую единицу. Наличие ошибки хотя бы в одной инструкции приведет к невозможности выполнения всего пакета. В то же время грамматический разбор не проверяет имена объектов и схем, так как сама схема может измениться в процессе выполнения инструкции.

 Файл сценария SQL и окно анализатора запросов (Query Analyzer) может содержать несколько пакетов. В данном случае все пакеты разделяют ключевые слова терминаторов. По умолчанию этим ключевым словом является GO, и оно должно быть единственным в строке. Все другие символы (даже комментарии) нейтрализуют разделитель пакета.

Отладка T-SQL

 Когда редактор SQL обнаруживает ошибку, он отображает ее характер и номер строки в пакете. Дважды щелкнув на ошибке, можно сразу же переместиться к соответствующей строке.

 В утилиту Management Studio версии SQL Server 2005 не включен отладчик языка T-SQL, — он присутствует в пакете Visual Studio.
SQL Server предлагает несколько команд, облегчающих отладку пакетов. В частности, команда PRINT отправляет сообщение без генерации результирующего набора данных. Команду PRINT можно использовать для отслеживания хода выполнения пакета. Когда анализатор запросов находится в режиме сетки, выполните следующий пакет:

 SELECT CityName FROM City WHERE IdCity = 1;

PRINT 'Контрольная точка';

 Результирующий набор данных отобразится в сетке и будет состоять из одной строки. В то же время во вкладке «Сообщения» отобразится следующий результат:

 (строк обработано: 1) Контрольная точка

 Переменные
Переменные T-SQL создаются с помощью команды DECLARE, имеющей следующий синтаксис:

 DECLARE @Имя_Переменной Тип_Данных [, @Имя_Переменной Тип_Данных, …]

 Все имена локальных переменных должны начинаться символом @. Например, для объявления локальной переменной UStr, которая хранит до 16 символов Unicode, можно использовать следующую инструкцию:

 DECLARE @UStr varchar(16)

 Используемые для переменных типы данных в точности совпадают с существующими в таблицах. В одной команде DECLARE через запятую может быть перечислено несколько переменных. В частности в следующем примере создаются две целочисленные переменные a и b:

 DECLARE
@a
int, @b int

 Область определения переменных (т.е. срок их жизни) распространяется только на текущий пакет. По умолчанию только что созданные переменные содержат пустые значения NULL и до включения в выражения должны быть инициализированы.

 Задание значений переменных

В настоящее время в языке SQL предусмотрены два способа задания значения переменной — для этой цели можно использовать оператор SELECT или SET. С точки зрения выполняемых функций эти операторы действуют почти одинаково, не считая того, что оператор SELECT позволяет получить исходное присваиваемое значение из таблицы, указанной в операторе SELECT.
Оператор SET обычно используется для задания значений переменных в такой форме, какая более часто встречается в процедурных языках. В качестве типичных примеров применения этого оператора можно указать следующие:

 SET @a = 1;

SET @b = @a * 1.5

 Обратите внимание на то, что во всех этих операторах непосредственно осуществляются операции присваивания, в которых используются либо явно заданные значения, либо другие переменные. С помощью оператора SET невозможно присвоить переменной значение, полученное с помощью запроса; запрос должен быть выполнен отдельно и только после этого полученный результат может быть присвоен с помощью оператора SET. Например, попытка выполнения такого оператора вызывает ошибку:

 DECLARE @c int

SET @c = COUNT(*) FROM City

SELECT @c

 а следующий оператор выполняется вполне успешно:

 DECLARE @c int

SET @c = (SELECT COUNT(*) FROM City)

SELECT @c

 Оператор SELECT обычно используется для присваивания значений переменным, если источником информации, которая должна быть сохранена в переменной, является запрос. Например, действия, осуществляемые в приведенном выше коде, гораздо чаще реализуются с помощью оператора SELECT:

 DECLARE @c int

SELECT @c = COUNT(*) FROM City

SELECT @c

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

 Оператор SET используется, если должна быть выполнена простая операция присваивания значения переменной, т.е. если присваиваемое значение уже задано явно в форме определенного значения или в виде какой-то другой переменной.

 Оператор SELECT применяется, если присваивание значения переменной должно быть основано на запросе.

 Использование переменных в запросах SQL
Одним из полезных свойств языка T-SQL является то, что переменные могут использоваться в запросах без необходимости создания сложных динамических строк, встраивающих переменные в программный код. Динамический SQL продолжает свое существование, но одиночное значение можно изменить проще — с помощью переменной.
Везде, где в запросе может использоваться выражение, может использоваться и переменная. В следующем примере продемонстрировано использование переменной в предложении WHERE:

 DECLARE @IdProd int;

SET @IdProd = 1;

SELECT [Description] FROM Product WHERE IdProd = @IdProd;

 Глобальные системные переменные 

В SQL Server имеется более тридцати глобальных переменных, не имеющих параметров, которые определяются и поддерживаются системой. Все глобальные переменные имеют префикс в виде двух символов @. Вы можете извлечь значение любой из них с помощью простого запроса SELECT, как в следующем примере:

 SELECT @@CONNECTIONS

  Здесь используется глобальная переменная @@CONNECTIONS для извлечения количества подключений к SQL Server со времени запуска программы.

 Среди наиболее часто применяемых системных переменных можно отметить следующие:

 @@ERROR - Содержит номер ошибки, возникшей при выполнении последнего оператора T-SQL в текущем соединении. Если ошибка не обнаружена, содержит 0. Значение этой системной переменной переустанавливается после выполнения каждого очередного оператора. Если требуется сохранить содержащееся в ней значение, то это значение следует переносить в локальную переменную сразу же после выполнения оператора, для которого должен быть сохранен код ошибки.

  •  @@IDENTITY - Содержит последнее идентификационное значение, вставленное в базу данных в результате выполнения последнего оператора INSERT. Если в последнем операторе INSERT не произошла выработка идентификационного значения, системная переменная @@IDENTITY содержит NULL. Это утверждение остается справедливым, даже если отсутствие идентификационного значения было вызвано аварийным завершением при выполнении оператора. А если с помощью одного оператора осуществляется несколько операций вставки, этой системной переменной присваивается только последнее идентификационное значение.
  •  @@ROWCOUNT - Одна из наиболее широко используемых системных переменных. Возвращает информацию о количестве строк, затронутых последним оператором. Обычно применяется для контроля ошибок, отличных от тех, которые относятся к категории ошибок этапа прогона программы. Например, если в программе обнаруживается, что после вызова на выполнение оператора DELETE с конструкцией WHERE количество затронутых строк равно нулю, то можно сделать вывод, что произошло нечто непредвиденное. После этого сообщение об ошибке может быть активизировано вручную.

! Следует отметить, что с версии SQL Server 2000 глобальные переменные принято называть функциями. Название глобальные сбивало пользователей с толку, позволяя думать, что область действия таких переменных шире, чем у локальных. Глобальным переменным часто ошибочно приписывалась возможность хранить информацию, независимо от того, включена она в пакет либо нет, что, естественно, не соответствовало действительности.

 Средства управления потоком команд. Программные конструкции

В языке T-SQL предусмотрена большая часть классических процедурных средств управления ходом выполнения программы, в т.ч. условная конструкция и циклы.

 Оператор IF. . . ELSE

 Операторы IF. . .ELSE действуют в языке T-SQL в основном так же, как и в любых других языках программирования. Общий синтаксис этого оператора имеет следующий вид:

 IF Логическое выражение SQL инструкция I BEGIN Блок SQL инструкций END [ELSE SQL инструкция | BEGIN Блок SQL инструкций END]

 В качестве логического выражения может быть задано практически любое выражение, результат вычисления которого приводит к возврату булева значения.

 Следует учитывать, что выполняемым по условию считается только тот оператор, который непосредственно следует за оператором IF (ближайшим к нему). Вместо одного оператора можно предусмотреть выполнение по условию нескольких операторов, объединив их в блок кода с помощью конструкции BEGIN…END.

 В приведенном ниже примере условие IF не выполняется, что предотвращает выполнение следующего за ним оператора.

 IF 1 = 0

PRINT 'Первая строка'

PRINT 'Вторая строка'

 Необязательная команда ELSE позволяет задать инструкцию, которая будет выполнена в случае, если условие IF не будет выполнено. Подобно IF, оператор ELSE управляет только непосредственно следующей за ним командой или блоком кода заключенным между BEGIN…END.

 Несмотря на то, что оператор IF выглядит ограниченным, его предложение условия может включать в себя мощные функции, подобно предложению WHERE. В частности это выражения IF EXISTS().

 Выражение IF EXISTS() использует в качестве условия наличие какой-либо строки, возвращенной инструкцией SELECT. Так как ищутся любые строки, список столбцов в инструкции SELECT можно заменить звездочкой. Этот метод работает быстрее, чем проверка условия @@ROWCOUNT>0, потому что не требуется подсчет общего количества строк. Как только хотя бы одна строка удовлетворяет условию IF EXISTS(), запрос может продолжать выполнение.

 В следующем примере выражение IF EXISTS используется для проверки наличия у клиента с кодом 1 каких-либо заказов перед удалением его из базы. Если по данному клиенту есть информация хотя бы по одному заказу, удаление не производится.

 IF EXISTS(SELECT * FROM [Order] WHERE IdCust = 1)
PRINT 'Невозможно удалить клиента поскольку в базе имеются связанные с ним записи'
ELSE
BEGIN
DELETE Customer
WHERE IdCust = 1
PRINT 'Удаление произведено успешно'
END

 Операторы WHILE, BREAK и CONTINUE

Оператор WHILE в языке SQL действует во многом так же, как и в других языках, с которыми обычно приходится работать программисту. По сути, в этом операторе до начала каждого прохода по циклу проверяется некоторое условие. Если перед очередным проходом по циклу проверка условия приводит к получению значения TRUE, осуществляется проход по циклу, в противном случае выполнение оператора завершается.

 Оператор WHILE имеет следующий синтаксис:

 WHILE Логическое выражение SQL инструкция I [BEGIN [BREAK] Блок SQL инструкций [CONTINUE] END]

 Безусловно, с помощью оператора WHILE можно обеспечить выполнение в цикле только одного оператора (по аналогии с тем, как обычно используется оператор IF), но на практике конструкции WHILE, за которыми не следует блок BEGIN. . .END, соответствующий полному формату оператора, встречаются редко.

 Оператор BREAK позволяет немедленно выйти из цикла, не ожидая того, как будет выполнен проход до конца цикла и произойдет повторная проверка условного выражения.

 Оператор CONTINUE позволяет прервать отдельную итерацию цикла. Кратко можно описать действие оператора CONTINUE так, что он обеспечивает переход в начало цикла WHILE. Сразу после обнаружения оператора CONTINUE в цикле, независимо от того, где он находится, происходит переход в начало цикла и повторное вычисление условного выражения (а если значение этого выражения больше не равно TRUE, осуществляется выход из цикла).

 Следующий короткий сценарий демонстрирует использование оператора WHILE для создания цикла:

 DECLARE @Temp int; SET @Temp = 0; WHILE @Temp < 3 BEGIN PRINT @Temp; SET @Temp = @Temp + 1; END

 Здесь в цикле целочисленная переменная @Temp увеличивается с 0 до 3 и на каждой итерации ее значение выводится на экран.

 Оператор RETURN 


Оператор RETURN используется для останова выполнения пакета, а следовательно, хранимой процедуры и триггера (рассматриваются в следующих лабораторных занятиях).


 

А также другие работы, которые могут Вас заинтересовать

85343. Методи дослідження психологічних особливостей людей з різними психофізичними порушеннями у спеціальній психології 39.99 KB
  Діагностика аномального розвитку дитини спрямована на визначення ступеня виразності психічної інтелектуальної емоційної мовної недостатності й на якісну оцінку структури дефекту з виділенням основного психопатологічного синдрому на встановлення звязків його з іншими клінічними проявами віком соматичним і неврологічним станом дитини. За допомогою бесіди можна виявити коло знань дитини про навколишню дійсність а також особливості її орієнтування в просторі часі явищах природи й громадському житті. У процесі бесіди психолог довідується...
85344. Загальна характеристика інвалідів (людей з обмеженими можливостями) як соціальної групи 40 KB
  У нашій країні якість життя інвалідів як правило нижче решти населення що обумовлено наступним: недостатністю в нашому суспільстві гуманізму і милосердя по відношенню до людей з особливими потребами; нерозвиненістю і непристосованістю соціальної інфраструктури міст і сільських населених пунктів з урахуванням задоволення основних потреб інвалідів; низьким рівнем матеріального забезпечення і соціального обслуговування їх недостатньою гнучкістю; низькою якістю чи відсутністю технічних засобів і пристосувань необхідних для...
85345. Девіантна поведінка. Причини виникнення девіантної поведінки 37.16 KB
  Причини виникнення девіантної поведінки. У соціології девіантної поведінки виділяються кілька напрямків що пояснюють причини виникнення такої поведінки. Мертон причиною поведінки що відхиляється вважає неузгодженість між цілями висунутими суспільством і засобами яке воно пропонує для їхнього досягнення. Особливої гостроти ця проблема набула сьогодні в нашій країні де всі сфери суспільного життя перетерплюють серйозні зміни відбувається девальвація колишніх норм поведінки.
85346. Наукові підходи до проблеми психології людини з обмеженими можливостями 41.76 KB
  Одними із осно вних понять в даній теорії в межах проблеми інвалідності є почуття неповноцінності компенсація комплекс неповноцінності. Він вважав що майже всі люди мають за мету подолання почуття неповноцінності однак це почуття у деяких людей може бути надмірним та пере рости у комплекс неповноцінності. Відомий психоаналітик вважав що комплекс неповноцінності у психоаналізі майже не вживається. Комплекс неповноцінності має глибоко еротичні корені.
85347. Методи корекції в системі психологічної допомоги людям з обмеженими можливостями 41.72 KB
  Одним із способів допомогти здоровим людям краще зрозуміти проблеми дітей з вадами здоровя навчитися надавати їм допомогу є програма Дитина дитині . Завданням цієї програми є навчити дітей шкільного віку та їх вчителів методам збереження свого здоровя й взаємодії з іншими дітьми особливо з тими хто має проблеми зі здоровям. Метою даної програми є допомогти дітям навчитися розрізняти різні види інвалідності і їх прояви; розуміти що незважаючи на те що людина у якої є фізичні вади може не справлятися з якоюсь роботою вона у той же...
85348. Загальні психолого-педагогічні аспекти реабілітації людини з обмеженими можливостями 35.77 KB
  Основними завданнями таких проектів психологореабілітаційного напрямку є відновлення та розвиток інтелектуальних функцій людини її емоційного стану навичок психічної саморегуляції комунікативної культури. Специфічними методами що використовуються у проектах для інвалідів є психологічні тренінги аутотренінг комунікативний тренінг тренінг креативності психотерапія ігротерапія бібліотерапія арттерапія та інше; соціальнокультурним який передбачає активізацію та розвиток творчохудожнього потенціалу дітей і дорослих засвоєння...
85349. Особливості розвитку людини з порушеннями інтелекту і психічними захворюваннями 42.36 KB
  Олігофренія одна з груп розумової відсталості різна за етіологією і патогенезом хворобливих змін обєднаних загальним клінічним проявом недорозвинення головного мозку. Олігофренія характеризується природженим або придбаним в ранньому дитинстві до 3 років загальним психічним недорозвиненням. У більшості з них спостерігалися недорозвинення мови й емоційновольова нестійкість. У структурі інтелектуального дефекту цієї групи дітей переважали недорозвинення зоровопросторових функцій труднощі встановлення послідовних умовиводів у розповідях...
85350. Депривація і особливості розвитку особистості дітей і підлітків із відхиленнями розвитку 38.99 KB
  Якщо подивитися на дітей з відхиленнями в дитинстві то емоційноособистісне спілкування з матірю не стає визначальним у розвитку дитини. Особливість психологічного статусу дитини з невеликими відхиленнями в розвитку це те що на ранньому етапі не залягали передумови становлення його психіки. Якщо не займатися з такою дитиною спеціальним розвитком і навчанням то зміни в емоційновольовій сфері дитини не відбудеться. Стрес повязаний з етапами шкільного життя з підвищенням вимог до дитини викликає певне психологічне напруження що часто...
85351. Основні завдання психологічної реабілітації людей з різними психофізичними порушеннями 39.57 KB
  Друга група завдань вивчення аномалії формування и розвитку конкретних форм психічної діяльності та її психічних процесів у різних груп аномальних дітей тобто вивчення закономірностей формування особистості розумової діяльності мови сприймання памяті. Діагностика психічного розвитку дитини містить у собі: o всебічне клінікопсихологічне вивчення особистості дитини та її батьків системи їхніх відносин; o аналіз мотиваційнопотребностної сфери дитини й членів її родини; o аналіз розвитку сенсорноперцептивних і інтелектуальних процесів...