Jump to content

SQL:1999

(Перенаправлено из SQL 3 )

SQL:1999 (также называемый SQL 3) — четвертая версия SQL к базе данных языка запросов . В нем появилось много новых функций, многие из которых потребовали разъяснений в последующем SQL:2003 . Тем временем [ нужны разъяснения ] SQL:1999 устарел.

Краткое содержание

[ редактировать ]

Стандартные документы ISO были опубликованы в период с 1999 по 2002 год в виде нескольких частей, первая из которых состояла из нескольких частей. В отличие от предыдущих изданий, в названии стандарта вместо дефиса использовалось двоеточие для соответствия названиям других стандартов ISO . Первая версия SQL:1999 состояла из пяти частей:

Впоследствии были опубликованы еще три части, также считавшиеся частью SQL:1999:

Новые возможности

[ редактировать ]

Типы данных

[ редактировать ]

Логические типы данных

[ редактировать ]

Стандарт SQL:1999 требует логического типа. [1] но многие коммерческие серверы SQL ( база данных Oracle , IBM Db2 ) не поддерживают его как тип столбца, тип переменной и не допускают его в наборе результатов. Microsoft SQL Server — одна из немногих систем баз данных, которая правильно поддерживает логические значения, используя тип данных «BIT». [ нужна ссылка ] . Каждые 1–8-битные поля занимают на диске один полный байт. MySQL интерпретирует «BOOLEAN» как синоним TINYINT (8-битное целое число со знаком). [2] PostgreSQL предоставляет соответствующий стандарту логический тип. [3]

Различные определяемые пользователем типы мощности

[ редактировать ]

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

create type age as integer FINAL;
create type salary as integer FINAL;

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

Немногие системы SQL поддерживают их. IBM Db2 — один из тех, кто их поддерживает. [4] База данных Oracle не поддерживала их с 2012 года, рекомендуя вместо этого эмулировать их с помощью одноместного структурированного типа . [5]

Структурированные пользовательские типы

[ редактировать ]

Они составляют основу расширения объектно-реляционной базы данных в SQL:1999. Они аналогичны классам объектно -ориентированных языков программирования . SQL:1999 допускает только одиночное наследование .

Общие табличные выражения и рекурсивные запросы

[ редактировать ]

В SQL:1999 добавлена ​​конструкция With [RECURSIVE], позволяющая рекурсивные запросы, такие как транзитивное замыкание указывать , в самом языке запросов; см. распространенные табличные выражения .

Некоторые OLAP возможности

[ редактировать ]

GROUP BY был расширен за счет ROLLUP, CUBE и GROUPING SETS.

Управление доступом на основе ролей

[ редактировать ]

Полная поддержка RBAC через CREATE ROLE.

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

[ редактировать ]

В SQL:1999 введено ключевое слово UNNEST. [6]

  1. ^ ISO / IEC 9075-2: 1999. Архивировано 24 декабря 2016 г. в Wayback Machine. разделе 4.6 Логические типы
  2. ^ «MySQL :: Справочное руководство MySQL 5.0 :: 11.4 Использование типов данных из других СУБД» . Dev.mysql.com. 09.01.2010. Архивировано из оригинала 7 февраля 2014 г. Проверено 30 января 2014 г.
  3. ^ «Документация PostgreSQL по логическому типу» . Архивировано из оригинала 9 марта 2018 г. Проверено 6 декабря 2023 г.
  4. ^ «Программное обеспечение IBM Information Management для Информационного центра решений z/OS» . Публикация.boulder.ibm.com . Проверено 30 января 2014 г.
  5. ^ «Соответствие Oracle базовому SQL:2003» . Документы.oracle.com. Архивировано из оригинала 2 декабря 2013 г. Проверено 30 января 2014 г.
  6. ^ Джонс, Ари; Стивенс, Райан К.; Плев, Рональд Р.; Гарретт, Роберт Ф.; Кригель, Алекс (2005). «Приложение B ANSI и ключевые слова поставщиков». Справочник программиста по функциям SQL . Джон Уайли и сыновья. п. 680. ИСБН  9780764598074 . Проверено 16 мая 2016 г.

Дальнейшее чтение

[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: c4ec5e37085fe8f57d1c633f2c5e85f2__1720336080
URL1:https://arc.ask3.ru/arc/aa/c4/f2/c4ec5e37085fe8f57d1c633f2c5e85f2.html
Заголовок, (Title) документа по адресу, URL1:
SQL:1999 - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)