CREATE VIEW
Запрос позволяет создать или заменить логическое представление в логической базе данных. Логическое представление можно создать на основе данных одной или нескольких логических таблиц.
В ответе возвращается:
- пустой объект ResultSet при успешном выполнении запроса;
- исключение при неуспешном выполнении запроса.
Если при обработке запроса происходит ошибка, последующее изменение сущностей логической базы данных невозможно. В этом случае нужно повторить запрос. Действие перезапустит обработку запроса, и после ее завершения можно будет продолжить работу с логической БД.
Каждое создание представления записывается в журнал. Журнал можно посмотреть с помощью запроса GET_CHANGES.
Синтаксис
Создание логического представления:
CREATE VIEW [db_name.]view_name AS SELECT query
Создание логического представления с заменой существующего представления, если такое будет найдено:
CREATE OR REPLACE VIEW [db_name.]view_name AS SELECT query
Параметры:
db_name
— имя логической базы данных, в которой создается или заменяется логическое представление. Опционально, если выбрана логическая БД, используемая по умолчанию;view_name
— имя создаваемого или заменяемого логического представления. В запросе на создание представления имя должно быть уникально среди логических сущностей логической БД;query
— SELECT-подзапрос, на основе которого строится логическое представление.
Ограничения
- Выполнение запроса недоступно при наличии любого из факторов:
- горячей дельты,
- незавершенного запроса на создание, удаление или изменение таблицы или представления,
- запрета на изменение сущностей (см. раздел DENY_CHANGES).
- Выполнение запроса недоступно в сервисной базе данных
INFORMATION_SCHEMA
. - Имена представления и его столбцов должны начинаться с латинской буквы, после первого символа могут следовать латинские буквы, цифры и символы подчеркивания в любом порядке.
- Представление и его столбцы не могут иметь имена, перечисленные в разделе Зарезервированные слова.
- В подзапросе
query
не допускается использование:- логических представлений,
- системных представлений
INFORMATION_SCHEMA
, - ключевого слова FOR SYSTEM_TIME.
- Ключевое слово
DATASOURCE_TYPE
, указанное в подзапросеquery
, игнорируется.
Пример
CREATE VIEW marketing.stores_by_sold_products AS
SELECT store_id, SUM(product_units) AS product_amount
FROM marketing.sales
GROUP BY store_id
ORDER BY product_amount DESC
LIMIT 20