ALTER TABLE ADD COLUMN
Содержание раздела
Поддерживается в версиях: 6.12 / 6.11 / 6.10 / 6.9 / 6.8 / 6.7 / 6.6 / 6.5 / 6.4 / 6.3 / 6.2 / 6.1 / 6.0.
Запрос добавляет столбец в указанную таблицу: логическую таблицу или прокси-таблицу. Столбец добавляется после всех существующих столбцов таблицы.
Запрос поддерживается для СУБД ADB, ADP и ADQM.
Результат выполнения
При успешном выполнении запроса система обновляет структуру таблицы в логической схеме данных, а структуру связанных физических таблиц — в хранилище данных.
После изменения структуры таблицы некоторые SELECT-запросы к логическим и материализованным представлениям, связанным с измененной таблицей, могут стать недоступными. В этом случае нужно пересоздать сбойные представления.
Как работает запрос
Запрос попадает в очередь операций и обрабатывается в порядке его поступления в очередь. Каждое изменение таблицы записывается в журнал, который можно посмотреть с помощью запроса GET_CHANGES.
Если при исполнении корректного запроса возникла ошибка, система блокирует все последующие DDL-запросы в логической базе данных. О снятии такой блокировки см. в разделе Снятие блокировки DDL-запросов.
Синтаксис
ALTER TABLE [db_name.]table_name
ADD COLUMN [IF NOT EXISTS] column_name datatype
[LOGICAL_ONLY]
Параметры:
db_name
-
Имя логической базы данных, которой принадлежит изменяемая таблица. Опционально, если выбрана логическая БД, используемая по умолчанию
table_name
-
Имя изменяемой логической таблицы или прокси-таблицы.
column_name
-
Имя добавляемого столбца таблицы.
datatype
-
Тип данных столбца
column_name
. Возможные значения см. в разделе Логические типы данных.
Ключевое слово IF NOT EXISTS
Ключевое слово IF NOT EXISTS
включает проверку наличия столбца до попытки добавления. Если ключевое слово указано в запросе, успешный ответ возвращается при наличии или успешном добавлении столбца, иначе — только при успешном добавлении столбца.
Ключевое слово LOGICAL_ONLY
Ключевое слово LOGICAL_ONLY
позволяет добавить столбец только в логической схеме данных, без обновления физической схемы данных.
Если ключевое слово не указано, столбец добавляется на логическом и физическом уровнях.
Варианты ответа
В ответе возвращается:
- пустой объект ResultSet при успешном выполнении запроса;
- исключение при неуспешном выполнении запроса.
Ограничения
Ограничения выполнения
- Запрос доступен для СУБД ADB, ADP и ADQM.
- Выполнение запроса к логической таблице недоступно, если она участвует в незавершенной операции записи.
- Выполнение запроса недоступно, если установлен запрет на изменение сущностей.
Ограничения имен
- Имя столбца должно быть уникально в рамках таблицы и соответствовать требованиям, описанным в разделе Соглашения об именах.
Ограничения партиционирования
- При добавлении столбца в партиционированную таблицу необходимо добавить соответствующий столбец во все ее партиции.
- При добавлении столбца в партицию необходимо добавить соответствующий столбец в связанную партиционированную таблицу и другие ее партиции.
Другие ограничения
- Можно добавить только nullable-столбец.
- После изменения таблицы запросы к связанным логическим и материализованным представлениям могут стать недоступными. В этом случае следует пересоздать сбойные представления.
- Информационная схема обновляется асинхронно, поэтому столбец может не сразу добавиться в информационную схему.
Примеры
Добавление столбца без ключевых слов
Добавление столбца в логическую таблицу указанной логической БД:
ALTER TABLE marketing.clients
ADD COLUMN description VARCHAR;
ALTER TABLE marketing.stores
ADD COLUMN previous_month_sales BIGINT;
Добавление столбца в прокси-таблицу указанной логической БД:
ALTER TABLE marketing.payments_proxy
ADD COLUMN manager_id BIGINT
Добавление столбца в логическую таблицу логической БД, выбранной по умолчанию:
USE marketing_new;
ALTER TABLE sales
ADD COLUMN manager_id BIGINT;
Добавление столбца с ключевым словом IF NOT EXISTS
ALTER TABLE marketing.clients
ADD COLUMN IF NOT EXISTS description VARCHAR
Добавление столбца с ключевым словом LOGICAL_ONLY
ALTER TABLE marketing_new.sales
ADD COLUMN client_id BIGINT
LOGICAL_ONLY