Синтаксис SQL

В этой статье описывается синтаксис SQL запросов. В следующем операторе задана минимальная структура и синтаксис, необходимый для SELECT.

SELECT [DISTINCT | ALL] {* | список_выбора} 
FROM {table_name [alias] | имя_представления}

Ключевые слова SQL

Ключевые слова (SELECT, GRANT, DELETE или CREATE) прописаны в синтаксисе SQL и имеют в этом языке предопределенное значение. Можно использовать ключевые слова в верхнем или нижнем регистре. Следующие три запроса равнозначны:

SELECT * FROM EMPLOYEES;
Select * FROM EMPLOYEES;
select * FROM EMPLOYEES;

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

DESCRIBE EMPLOYEES;
DESC EMPLOYEES;

Идентификаторы

Идентификаторы – это имена заданные разработчиками для структурных элементов базы данных: таблицы, столбцы, псевдонимы, индексы, представления. В синтаксисе последнего SQL запроса 'EMPLOYEES' - это идентификатор, а 'SELECT' - ключевое слово. Правила для создания идентификаторов указываются в спецификации поставщика. Рассмотрим следующую таблицу:

ПравилаПлатформаОписание
Идентификатор должен содержать доSQL2003128 символов.
DB2128 символов, в зависимости от платформы.
MySQL64 символа.
Oracle30 байт; имена базы данных до 8 байт.
PostgreSQL31 символ.
Идентификатор может содержатьSQL2003Любые цифры, символы и нижнее подчеркивание.
DB2Любые цифры, символы в верхнем регистре или символ нижнего подчеркивания.
MySQLЛюбые цифры или символы.
OracleЛюбые цифры, символы и нижнее подчеркивание (_), знак фунта стерлингов (#) или доллара ($).
PostgreSQLЛюбые цифры, символы и нижнее подчеркивание (_).
Первый символ должен бытьSQL2003Буквой.
DB2Буквой.
MySQLБуквой или цифрой (но не должен содержать только цифры).
OracleБуквой.
PostgreSQLБуквой или нижним подчеркиванием (_).
Идентификатор не может содержатьSQL2003Специальные символы или пробелы.
DB2Специальные символы или пробелы.
MySQLТочку (.), слэш (/) или ASCII(0) и ASCII(255). Кавычки (') и двойные кавычки (") допускаются только в ссылающихся идентификаторах.
OracleПробелы, двойные кавычки (") или специальные символы.
PostgreSQLДвойные кавычки (").
В синтаксисе SQL запросов символ идентификатораSQL2003Двойные кавычки (").
DB2Двойные кавычки (").
MySQLКавычки ( ' ) или двойные кавычки (" ) в режиме совместимости с ANSI.
OracleДвойные кавычки (").
PostgreSQLДвойные кавычки (").
Идентификатор может быть зарезервированSQL2003Нет, кроме ссылающихся идентификаторов.
DB2Да.
MySQLНет, кроме ссылающихся идентификаторов.
OracleНет, кроме ссылающихся идентификаторов.
PostgreSQLНет, кроме ссылающихся идентификаторов.
Адресация к схемеSQL2003Каталог.схема.объект.
DB2Схема.объект.
MySQLБаза_данных.объект.
OracleСхема.объект.
PostgreSQLБаза_данных.схема.объект.
Идентификатор должен быть уникальнымSQL2003Да.
DB2Да.
MySQLДа.
OracleДа.
PostgreSQLДа.

Конвенции имен

Стандарт SQL не содержит никаких точных указаний по наименованиям, поэтому нужно следовать следующим основным принципам (в том числе и в синтаксисе SQL запросов UPDATE):

  • Выбирайте имя, которое содержит смысл и имеет описательный характер. Например, таблица сотрудников не должна называться emp, а столбец имени сотрудника должен называться first_name, а не fname, хотя и «emp», и «fname» это допустимые идентификаторы;
  • Используйте для всех объектов в базе данных SQL либо заглавные буквы, либо строчные, поскольку некоторые серверы баз данных чувствительны к регистру.

Литералы SQL

Термин литералы относится к фиксированным значениям данных. SQL распознает четыре типа литералов: числовые значения, строки символов, дата или время, логическое значение. Например, 100, -120, 544, 03, -458, 25, 3e2, 5E-2 являются действительными числовыми литералами. 'США', '2000', 'SQL Синтаксис', '1 января 1981' являются действительными строками символов (должны быть заключены в одинарные кавычки (' ')). Логические литералы и литералы даты/времени выглядят следующим образом: TRUE и 'JAN-28-1976 21:12:40:00'.

Операторы

Операторы работают с отдельными элементами данных и возвращают результат. Операторы используются в различных операциях SQL, таких как SELECT, INSERT, UPDATE или DELETE. А также при создании различных объектов базы данных, таких как функции, представления, триггеры и хранимые процедуры. MS SQL синтаксис запросов поддерживает различные типы операторов, хотя не все СУБД поддерживают все операторы.

Смотрите таблицу ниже:

ОператорыРаботают во
Арифметические операторыВсех базах данных.
Операторы присвоенияВсех базах данных.
Побитовые операторыMicrosoft SQL Server.
Операторы сравненияВсех базах данных.
Логические операторыDB2, Oracle, SQL Server и PostgreSQL.
Унарные операторыDB2, Oracle и SQL Server.

Приоритетность операторов

Приоритетность - это порядок, в котором база данных оценивает различные операторы в одном выражении. В синтаксисе SQL запросов при выполнении выражения, содержащего несколько операторов (например, +, -, /), сначала выполняются операторы с высшей приоритетностью, а затем с более низкой. При оценке операторов с одинаковой приоритетностью операторы выполняются в порядке их расстановки в выражении слева направо.

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

Приоритетность операторов
( ) (выполняются в первую очередь).
+, -, ~ (унарные операторы).
*, /, % (математические операторы).
+, - (арифметические операторы).
=, >, <, >=, <=, <>, !=, !>, !< (операторы сравнения).
I^ (Побитовый OR), & (Побитовый AND), | (Побитовый OR).
NOT.
AND.
ALL, ANY, BETWEEN, IN, LIKE, OR, SOME.
= (присвоение переменных).

Следующие выражения в запросе MySQL возвращают разные результаты:

SELECT 12 * 2 + 24;

Результат

12 * 2 + 24
48

Приоритетность операторов

Приоритетность операторов

SELECT 12 * (2 + 24)

Результат

12 * (2 + 24)
312

Приоритетность операторов

Приоритетность операторов

Комментарии SQL

Комментарии в синтаксисе SQL запросов - это необязательный текст, который описывает, что делает программа и почему код был изменен. Компилятор всегда игнорирует комментарии. Комментарий вводится через двойное тире и пробел:
-- Это комментарий SQL

В качестве альтернативы, можно использовать блок комментариев C-стиля:

/ * Это первая строка комментария
Это вторая строка комментария * /.

Пробелы

Пробелы, как правило, игнорируются в операторах SQL, что позволяет проще форматировать код для удобства чтения.
На следующей диаграмме приведены элементы синтаксиса SQL запросов, которые составляют одиночный оператор:

Пробелы

Список ключевых слов SQL:

ABSOLUTEACTIONADDADMIN
AFTERAGGREGATEALIASALL
ALLOCATEALTERANDANY
AREARRAYASASC
ASSERTIONASSERTIONATATOMIC
AUTHORIZATIONBEFOREBEGINBIGINT
BINARYBITBLOBBOOLEAN
BOTHBREADTHBYCALL
CASCADECASCADEDCASECAST
CATALOGCHARCHARACTERCHECK
CLASSCLOBCLOSECOLLATE
COLLATIONCOLLECTCOLUMNCOMMIT
COMPLETIONCONDITIONCONNECTCONNECTION
CONSTRAINTCONSTRAINTSCONSTRUCTORCONTAINS
CONTINUECORRESPONDINGCREATECROSS
CUBECURRENTCURRENT_DATECURRENT_PATH
CURRENT_ROLECURRENT_TIMECURRENT_TIMESTAMPCURRENT_USER
CURSORCYCLEDATADATALINK
DATEDAYDEALLOCATEDEC
DECIMALDECLAREDEFAULTDEFERRABLE
DELETEDEPTHDEREFDESC
DESCRIPTORDESTRUCTORDIAGNOSTICSDICTIONARY
DISCONNECTDODOMAINDOUBLE
DROPELEMENTEND-EXECEQUALS
ESCAPEEXCEPTEXCEPTIONEXECUTE
EXITEXPANDEXPANDINGFALSE
FIRSTFLOATFORFOREIGN
FREEFROMFUNCTIONFUSION
GENERALGETGLOBALGOTO
GROUPGROUPINGHANDLERHASH
HOURIDENTITYIFIGNORE
IMMEDIATEININDICATORINITIALIZE
INITIALLYINNERINOUTINPUT
INSERTINTINTEGERINTERSECT
INTERSECTIONINTERVALINTOIS
ISOLATIONITERATEJOINKEY
LANGUAGELARGELASTLATERAL
LEADINGLEAVELEFTLESS
LEVELLIKELIMITLOCAL
LOCALTIMELOCALTIMESTAMPLOCATORLOOP
MATCHMEMBERMEETSMERGE
MINUTEMODIFIESMODIFYMODULE
MONTHMULTISETNAMESNATIONAL
NATURALNCHARNCLOBNEW
NEXTNONONENORMALIZE
NOTNULLNUMERICOBJECT
OFOFFOLDON
ONLYOPENOPERATIONOPTION
ORORDERORDINALITYOUT
OUTEROUTPUTPADPARAMETER
PARAMETERSPARTIALPATHPERIOD
POSTFIXPRECEDESPRECISIONPREFIX
PREORDERPREPAREPRESERVEPRIMARY
PRIORPRIVILEGESPROCEDUREPUBLIC
READREADSREALRECURSIVE
REDOREFREFERENCESREFERENCING
RELATIVEREPEATRESIGNALRESTRICT
RESULTRETURNRETURNSREVOKE
RIGHTROLEROLLBACKROLLUP
ROUTINEROWROWSSAVEPOINT
SCHEMASCROLLSEARCHSECOND
SECTIONSELECTSEQUENCESESSION
SESSION_USERSETSETSSIGNAL
SIZESMALLINTSPECIFICSPECIFICTYPE
SQLSQLEXCEPTIONSQLSTATESQLWARNING
STARTSTATESTATICSTRUCTURE
SUBMULTISETSUCCEEDSSUMSYSTEM_USER
TABLETABLESAMPLETEMPORARYTERMINATE
THANTHENTIMETIMESTAMP
TIMEZONE_HOURTIMEZONE_MINUTETOTRAILING
TRANSACTIONTRANSLATIONTREATTRIGGER
TRUEUESCAPEUNDERUNDO
UNIONUNIQUEUNKNOWNUNTIL
UPDATEUSAGEUSERUSING
VALUEVALUESVARCHARVARIABLE
VARYINGVIEWWHENWHENEVER
WHEREWHILEWITHWRITE
YEARZONE

Вадим Дворниковавтор-переводчик статьи «SQL Syntax»

Пожалуйста, оставьте свои комментарии по текущей теме статьи. Мы крайне благодарны вам за ваши комментарии, отклики, дизлайки, лайки, подписки!