ALTER VIEW
Содержание раздела
Запрос изменяет логическое представление в логической базе данных.
Запрос попадает в очередь операций и обрабатывается в порядке его поступления в очередь. В ответе возвращается:
- пустой объект ResultSet при успешном выполнении запроса;
- исключение при неуспешном выполнении запроса.
Ошибка выполнения корректного запроса блокирует исполнение последующих запросов в этой логической базе данных. В случае блокировки нужно устранить причины сбоя и повторить сбойную операцию. Если повторение операции невозможно, удалите сбойную операцию запросом ERASE_CHANGE_OPERATION и вручную устраните несоответствия на физическом уровне (если такие есть).
Логическое представление можно также изменить с помощью запроса CREATE OR REPLACE VIEW
(см. CREATE VIEW).
Каждое изменение представления записывается в журнал. Журнал можно посмотреть с помощью запроса GET_CHANGES.
Синтаксис
ALTER VIEW [db_name.]view_name AS SELECT query
Параметры:
db_name
-
Имя логической базы данных, в которой находится логическое представление. Опционально, если выбрана логическая БД, используемая по умолчанию.
view_name
-
Имя изменяемого логического представления.
query
-
SELECT-подзапрос, на основе которого строится новый вид логического представления.
Ограничения
Ограничения выполнения
- Выполнение запроса недоступно при наличии любого из факторов:
- горячей дельты,
- запрета на изменение сущностей (см. раздел DENY_CHANGES).
- Запрос не может быть выполнен в сервисной базе данных
INFORMATION_SCHEMA
.
Ограничения SELECT-подзапроса
- SELECT-подзапрос не может содержать:
- логические и материализованные представления,
- системные представления
INFORMATION_SCHEMA
, - ключевое слово FOR SYSTEM_TIME.
- Ключевое слово
DATASOURCE_TYPE
, указанное в SELECT-подзапросе, игнорируется.
Пример
ALTER 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 ASC
LIMIT 20