Просмотр (SQL) - View (SQL)

Представление похоже на окно, в котором можно просматривать или изменять данные из таблиц. Таблица, на которой основывается, называется лучшей таблицей. Представление - это Tod как оператор SELECT в словаре данных. база данных, а Посмотреть это набор результатов из хранится запрос на данные, который база данных пользователи могут делать запросы так же, как и в постоянном объекте коллекции базы данных. Эта предустановленная команда запроса хранится в словаре базы данных. В отличие от обычных базовые таблицы в реляционная база данных, представление не является частью физическая схема: в качестве результирующего набора это виртуальная таблица, которая динамически вычисляется или сопоставляется с данными в базе данных, когда запрашивается доступ к этому представлению. Изменения, внесенные в данные в соответствующем базовая таблица отражаются в данных, отображаемых при последующих вызовах представления. В некоторых NoSQL базы данных, представления - единственный способ запрашивать данные[как? ].

Представления могут иметь преимущества перед таблицами:

  • Представления могут представлять подмножество данных, содержащихся в таблице. Следовательно, представление может ограничивать степень раскрытия базовых таблиц внешнему миру: у данного пользователя может быть разрешение на запрос представления, но ему запрещен доступ к остальной части базовой таблицы.
  • Просмотры могут присоединиться и упростить несколько таблиц в единую виртуальную таблицу.
  • Представления могут действовать как агрегированные таблицы, где ядро базы данных объединяет данные (сумма, средний и т. д.) и представляет результаты расчетов как часть данных.
  • Представления могут скрыть сложность данных. Например, представление может прозрачно отображаться как Sales2000 или Sales2001. разделение фактическая базовая таблица.
  • Представления занимают очень мало места для хранения; база данных содержит только определение представления, а не копию всех данных, которые он представляет.
  • В зависимости от SQL используется движок, просмотры могут обеспечить дополнительную безопасность.

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

Как только ряды в базовой таблице отсутствует определенный порядок, строки, доступные в представлении, не отображаются с сортировкой по умолчанию. Представление - это реляционная таблица, а реляционная модель определяет таблицу как набор строк. Поскольку наборы не упорядочены по определению, то же самое и строки представления. Следовательно, СОРТИРОВАТЬ ПО предложение в определении представления не имеет смысла; стандарт SQL (SQL: 2003 ) не допускает предложение ORDER BY в подзапросе команды CREATE VIEW, так же как оно отклонено в операторе CREATE TABLE. Однако отсортированные данные можно получить из представления так же, как и любую другую таблицу, - как часть запроса. утверждение с этой точки зрения. Тем не менее, некоторые СУБД (например, База данных Oracle ) не соблюдают это стандартное ограничение SQL.

Доступные только для чтения и обновляемые представления

Специалисты по базам данных могут определять представления как только чтение или обновляемый. Если система базы данных может определить обратное отображение схемы представления в схему базовых базовых таблиц, тогда представление можно обновлять. ВСТАВЛЯТЬ, ОБНОВИТЬ, и УДАЛИТЬ операции могут выполняться с обновляемыми представлениями. Представления только для чтения не поддерживают такие операции, потому что СУБД не может отобразить изменения в лежащих в основе базовых таблицах. Обновление представления выполняется путем сохранения ключей.

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

Материализованные представления

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

Материализованные представления были введены База данных Oracle, пока IBM DB2 для той же цели предоставляет так называемые «материализованные таблицы запросов» (MQT). Microsoft SQL Server представленные в версии 2000 года индексированные представления, которые хранят только отдельный индекс из таблицы, но не все данные. PostgreSQL реализованы материализованные представления в версии 9.3.

Эквивалентность

Представление эквивалентно исходному запросу. Когда запросы выполняются для представлений, запрос изменяется. Например, если существует представление с именем accounts_view со следующим содержимым:

- accounts_view:-------------ВЫБРАТЬ имя,       money_received,       money_sent,       (money_received - money_sent) В КАЧЕСТВЕ баланс,       адрес,	   ...  ИЗ table_customers c   ПРИСОЕДИНИТЬСЯ account_table а     НА а.Пользовательский ИД = c.Пользовательский ИД

тогда приложение может выполнить простой запрос, например:

- Простой запрос------------ВЫБРАТЬ имя,       баланс  ИЗ accounts_view

Затем СУБД принимает простой запрос, заменяет эквивалентное представление, а затем отправляет следующее в оптимизатор запросов:

- Предварительно обработанный запрос:------------------ВЫБРАТЬ имя,       баланс  ИЗ (ВЫБРАТЬ имя,               money_received,               money_sent,               (money_received - money_sent) В КАЧЕСТВЕ баланс,               адрес,			    ...          ИЗ table_customers c ПРИСОЕДИНИТЬСЯ account_table а               НА а.Пользовательский ИД = c.Пользовательский ИД        )

Затем оптимизатор удаляет ненужные поля и сложность (например: нет необходимости читать адрес, поскольку родительский вызов не использует его), а затем отправляет запрос механизму SQL для обработки.

Смотрите также

внешняя ссылка