Вход/Регистрация
Firebird РУКОВОДСТВО РАЗРАБОТЧИКА БАЗ ДАННЫХ
вернуться

Борри Хелен

Шрифт:

Firebird не позволит вам изменить тип данных столбца или домена, в результате чего могут потеряться данные.

* Новое определение столбца должно позволять использовать существующие данные. Если, например, новый тип данных имеет слишком много байтов, или не поддерживается преобразование типов данных, то возвращается ошибка, и изменения не выполняются.

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

* Преобразование символьных данных в несимвольные недопустимо.

* Столбцы массивов и BLOB не могут быть преобразованы.

! ! !

ВНИМАНИЕ! Любые изменения определения полей могут потребовать пересоздания индексов.

. ! .

Удаление столбцов

Владелец таблицы может использовать ALTER TABLE для удаления определения столбца и его данных из таблицы. Удаление столбца приводит к потере всех хранимых в нем данных. Удаление приводит к немедленному эффекту, независимо от других транзакций, работающих с таблицей. В этом случае другая транзакция продолжается без прерывания, a Firebird откладывает удаление до освобождения таблицы.

До удаления столбца учтите условия, при которых невозможно будет выполнить удаление. Удаление будет ошибочным, если столбец:

* является частью ограничения UNIQUE, PRIMARY KEY или FOREIGN KEY;

* включен в ограничение CHECK (это могут быть ограничения CHECK на уровне таблицы для основанного на домене столбца в дополнение к ограничению его домена);

* используется в просмотре, триггере или хранимой процедуре.

Зависимости должны быть удалены до удаления столбца. Столбцы, включенные в состав ограничений PRIMARY KEY и UNIQUE, не могут быть удалены, если на них есть ссылки в ограничениях FOREIGN KEY. В этом случае удалите ограничение FOREIGN KEY до удаления ограничения PRIMARY KEY или UNIQUE. После этого удаляйте столбец.

Синтаксис:

ALTER TABLE имя-таблицы DROP имя-столбца [, имя-столбца ...];

Например, следующий оператор удаляет столбец JOB_GRADE из таблицы EMPLOYEE:

ALTER TABLE EMPLOYEE DROP JOB_GRADE;

Удаление нескольких столбцов в одном операторе:

ALTER TABLE EMPLOYEE

DROP JOB_GRADE,

DROP FULL NAME;

Удаление ограничений

Необходимо выполнять удаление ограничений в правильной последовательности, если ограничения PRIMARY KEY и CHECK имеют зависимости.

! ! !

СОВЕТ. Для поиска имен ограничений может оказаться полезным выполнение четырех системных просмотров, определенных в скрипте system_views.sql, представленном в приложении 9.

. ! .

Ограничения UNIQUE KEY и PRIMARY KEY

При удалении ограничений первичного и уникального ключа необходимо вначале найти и удалить все ссылающиеся на них ограничения внешних ключей. Если речь идет об уникальном ключе, то объявление внешнего ключа перечисляет имена столбцов уникального ключа, например:

. . .

FK_DATA_ID FOREIGN KEY DATA_ID

REFERENCES TEST_UQ (DATA_I D) ;

Если ключ, на который имеются ссылки, является первичным ключом, то имя столбца первичного ключа является необязательным в объявлениях внешнего ключа и часто опускается. Например, посмотрите на базу данных ../samples/employee.gdb:

...TABLE PROJECT (

. . . ,

TEAM_CONSTRT FOREIGN KEY(TEAM_LEADER)

REFERENCES EMPLOYEE );

Удаление ограничения внешнего ключа простое:

ALTER TABLE PROJECT

DROP CONSTRAINT TEAM_CONSTRT;

COMMIT;

После этого становится возможным удаление ограничения первичного ключа для столбца EMP_NO таблицы EMPLOYEE:

ALTER TABLE EMPLOYEE

DROP CONSTRAINT EMP_NO_CONSTRT ;

Ограничения CHECK

Любые условия CHECK, которые были добавлены в процессе определения таблицы, могут быть удалены без каких-либо осложнений. Условия CHECK, наследуемые от домена, являются более проблематичными. Для освобождения от ограничений домена необходимо выполнить операцию ALTER TABLE ALTER COLUMN ... TYPE для изменения типа данных столбца или указания другого домена.

Добавление столбца

Один или более столбцов можно добавить в таблицу в одном операторе при использовании предложения ADD. Каждое предложение ADD включает полное определение столбца. Используется тот же самый синтаксис, что и при определении столбца в операторе CREATE TABLE. Предложения ADD отделяются друг от друга запятыми.

Синтаксис:

ALTER TABLE таблица ADD <определение-столбца>

<определение-столбца> = столбец

  • Читать дальше
  • 1
  • ...
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: