| ADD; Столбец будет добавлен со значением NULL для всех строк таблицы. Но- вый столбец станет последним по порядку столбцом таблицы. Вообще то, можно добавить сразу несколько новых столбцов, отделив их запятыми, в однй команде. Имеется возможность удалять или изменять столбцы. Наибо- лее часто, изменением столбца может быть просто увеличение его разме- ра, или добавление( удаление ) ограничения. Ваша система должна убе- диться, что любые изменения не противоречат существующим данным — нап- ример при попытке добавить ограничение к столбцу который уже имел зна- чение при нарушении которого ограничение будет отклонено. Лучше всего дважды проверить это. По крайней мере, посмотрите документацию вашей системы чтобы убедиться, гарантирует ли она что именно это было причи- ной. Из-за нестандартного характера команды ALTER TABLE, вам все равно необходимо посмотреть тот раздел вашей системной документации где го- ворится об особых случаях. ALTER TABLE — не действует, когда таблица должна быть переопределе- на, но вы должны разрабатывать вашу базу данных по возможности так чтобы не слишком ей в этом передоверяться. Изменение структуры таблицы когда она уже в использовании — опасно! Просмотрите внимательно табли- цы, которые являясь вторичными таблицами с извлечеными данными из дру- гой таблицы ( смотри Главу 20 ), не долго правильно работают, а прог- раммы использующие вложенный SQL( Глава 25 ) выполняются неправильно или не всегда проавильно. Кроме того, изменение может стереть всех пользователей имеющих разрешение обращаться к таблице. По этим причи- нам, вы должны разрабатывать ваши таблицы так, чтобы использовать AL- TER TABLE только в крайнем случае. Если ваша система не поддерживает ALTER TABLE, или если вы хотите избежать ее использования, вы можете просто создать новую таблицу, с необходимыми изменениями при создании, и использовать команду INSERT с SELECT * запросом чтобы переписать в нее данные из старой таблицы. Пользователям которым был предоставлен доступ к старой таблице ( см. Главу 22 ) должен быть предоставлен доступ к новой таблице. ============= УДАЛЕНИЕ ТАБЛИЦ =============== Вы должны быть собственником( т.е. быть создателем ) таблицы чтобы иметь возможность удалить ее. Поэтому не волнуйтесь о случайном разру- шении ваших данных, SQL сначала потребует чтобы вы очистили таблицу прежде, чем удалит ее из базы данных. Таблица с находящимися в ней строками, не может быть удалена. Обратитесь к Главе 15 за подробностя- ми относительно того как удалять строки из таблицы. Синтаксис для уда- ления вашей таблицы, если конечно она является пустой, следующая: DROP TABLE < table name >; При подаче этой команды, имя таблицы больше не распознается и нет такой команды которая могла быть дана этому объекту. Вы должны убе- диться, что эта таблица не ссылается внешним ключом к другой таблице( Внешние ключи обсуждаются в Главе 19 ), и что она не используется в определении Представления( Глава 20 ). Эта команда фактически не является частью стандарта ANSI, но она об- ще поддерживаема и полезна. К счастью, она более проста, и следова- тельно более непротиворечива, чем ALTER TABLE. ANSI просто не имеет способа для определения разрушеных или неправильных таблиц. =============== РЕЗЮМЕ =============== Теперь Вы уже бегло ориентируетесь в основах определений данных. Вы можете создавать, изменять, и удалять таблицы. В то время как только первая из этих функций — часть официального стандарта SQL, другие бу- дут время от времени меняться, особенно — ALTER TABLE. DROP TABLE поз- воляет вам избавиться от таблиц которые бесполезны. Она уничтожает только пустые таблицы, и следовательно не разрушает данные. Вы теперь знаете об индексах а также, как их создавать и удалять. SQL не дает вам большого управления над ими, так как реализация кото- рую вы используете довольно удачно определяет, как быстро выполняются различные команды. Индексы — это один из инструментов дающий Вам воз- можность воздействовать непосредственно на эффективность ваших команд в SQL. Мы рассмотрели индексы здесь чтобы отличать их от ограничений, с которыми их нельзя путать. Ограничения — это тема Главы 18 и Главы 19. **************** РАБОТА С SQL ************ 1. Напишите предложение CREATE TABLE которое бы вывело нашу таблицу Заказчиков. 2. Напишите команду которая бы давала возможность пользователю быстро извлекать порядки сгруппированные по датам из таблицы Порядков. 3. Если таблица Порядков уже создана, как Вы можете заставить поле onum быть уникальным (если допустить что все текущие значения уни- кальны)? 4. Создайте индекс который бы разрешал каждому продавцу быстро отыски- вать его порядки сгруппированные по датам. 5. Предположим, что каждый продавец имеет только одного заказчика с данной оценкой, введите команду которая его извлечет. ( См. Приложение A для ответов. ) |