Поможем написать учебную работу
Если у вас возникли сложности с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой - мы готовы помочь.

Предоплата всего

Подписываем
Если у вас возникли сложности с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой - мы готовы помочь.
Предоплата всего
Подписываем
Лабораторная работа №3.
Изменение таблицы. Выбор данных из таблиц.
ALTER/MODIFY
ALTER [IGNORE] TABLE table ADD [COLUMN] create_clause
ALTER [IGNORE] TABLE table ADD INDEX [name] (column, . . .)
ALTER [IGNORE] TABLE table ADD UNIQUE [name] (column, . . .)
ALTER [IGNORE] TABLE table ALTER [COLUMN] column SET DEFAULT value
ALTER [IGNORE] TABLE table ALTER [COLUMN] column DROP DEFAULT
ALTER [IGNORE] TABLE table CHANGE [COLUMN] column create..clause
ALTER [IGNORE] TABLE table DROP [COLUMN] column
ALTER [IGNORE] TABLE table DROP FOREIGN KEY key
ALTER [IGNORE] TABLE table DROP INDEX key
ALTER [IGNORE] TABLE table DROP PRIMARY KEY
ALTER [IGNORE] TABLE table MODIFY [COLUMN] create_clause
ALTER [IGNORE] TABLE table RENAME [AS] new_name
Оператор ALTER охватывает широкий набор действий, которые изменяют структуру таблицы. Этот оператор используется для добавления, изменения или удаления столбцов существующей таблицы, а также для удаления индексов. Несколько операторов ALTER могут быть объединены в одно предложение с помощью запятых:
ALTER TABLE mytable DROP myoldcolumn, ADD mynewcolumn INT
Для модификации таблицы MySQL создает копию таблицы и изменяет ее, выполняя все модифицирующие запросы. Когда все изменения сделаны, старая таблица удаляется, а ее место занимает новая таблица. В этой точке выполняются все поставленные в очередь запросы. В целях безопасности, если какой-либо из запросов создает дублирующие ключи, которые должны быть уникальными, предложение ALTER откатывается и отменяется. Если в предложении присутствует ключевое слово IGNORE, дублированные уникальные ключи игнорируются, и запрос ALTER исполняется как обычно. Имейте в виду, что использование IGNORE для активной таблицы с уникальными ключами может привести к искажению и порче таблицы.
Как указывалось выше, есть несколько разных, зачастую противоположных действий, выполняемых ALTER:
ADD [COLUMN] create,clause
Добавляет новый столбец в таблицу. Выражение create_clause имеет тот же вид, что и используемое в операторе CREATE (см. ниже). Таблица должна существовать и не иметь столбца с тем же именем, что у добавляемого столбца. (Ключевое слово COLUMN необязательно и не имеет эффекта.)
ADD INDEX [ name] (column , ...)
Создает индекс из указанных столбцов. В индексе могут быть скомбинированы до 15 столбцов. Указывать имя для индекса необязательно. Если не задано имя, индекс будет назван по имени первого столбца в списке (с числовым суффиксом _2, _3 и т. д., если это необходимо для уникальности).
ADD UNIQUE [name] (column, ...)
Идентично ADD INDEX за исключением того, что индексированные поля гарантированно уникальны. То есть, если пользователь попытается добавить значение, уже существующее в уникальном индексе, будет выдано сообщение об ошибке.
ALTER [COLUMN] column SET DEFAULT value
ALTER [COLUMN] column DROP DEFAULT
Создает, изменяет или удаляет значение по умолчанию для столбца. Если используется фраза SET DEFAULT , значение по умолчанию для указанного столбца изменяется на новое (даже если до этого не существовало значений по умолчанию). При использовании DROP DEFAULT, существующее значение по умолчанию удаляется. При этом любые существующие записи, созданные с помощью этого значения, остаются неизмененными. (Ключевое слово COLUMN необязательно и не имеет эффекта.)
CHANGE [COLUMN] new_column_name create_clause
MODIFY [COLUMN] create__clause
Изменяет определение столбца. Предложение используется для изменения типа данных столбца с минимально возможным воздействием на данные. Выражение create_clause то же, что и в операторе CREATE. Оно включает имя столбца и поэтому, используя это предложение, вы изменяете имя столбца. (Например, ALTER TABLE mytable CHANGE name newname CHAR(30) .) Предложение MODIFY аналогично CHANGE, но новый столбец имеет то же имя, что и старый. Ключевое слово COLUMN необязательно и не имеет эффекта. Следующие преобразования типов данных выполняются автоматически:
Целых чисел к числам с плавающей запятой, и наоборот (например, BIGINT к DOUBLE).
Меньших числовых значений к большим (например, INTEGER к BIGINT).
Больших числовых значений к меньшим (например, DOUBLE к FLOAT). Если значение выходит за пределы нового типа, используется максимально возможное значение нового типа данных (или наименьшее из отрицательных).
Примеры
# Добавить поле 'address2' к таблице 'people' и. задать ему тип данных
# 'VARCHAR' с максимальной длиной 200 символов.
# Добавить два новых индекса к таблице 'hr', обычный индекс для поля
# 'salary'
# и уникальный индекс для поля 'id'. Также продолжить выполнение, если
# найдены
# дублируемые значения при создании индекса 'id_idx' (очень опасно!).
# Изменить значение по умолчанию для поля 'price' в таблице 'sprockets'
# на $19.95.
# Удалить значение по умолчанию для поля 'middle_name' в таблице 'names'.
# Изменить тип данных для поля 'profits' с начального значения (которым,
# возможно, было INTEGER) на BIGINT.
# Удалить поле 'secret_stuff' из таблицы 'not_private_anymore'
# удалить индекс с именем 'id_index' также как и первичный ключ
# из таблицы 'cars'.
# Переименовать таблицу 'rates_current' на 'rates_1997'
SELECT
Выбирает данные из таблицы. Оператор SELECT является основным методом чтения данных из таблиц баз данных.
Если вы укажете несколько таблиц, mSQL автоматически объединит таблицы для сравнения записей.
Если указано ключевое слово DISTINCT, будет показана только одна запись из каждой группы одинаковых записей возвращаемого набора.
Имена столбцов могут быть указаны как column или как table, column . Длинная форма необходима только для того, чтобы отличать столбцы с одинаковыми именами, но ее можно использовать в любое время (например, SELECT name FROM people; SELECT people, name FROM people ).
Список таблиц для соединения указывается как Table1, Table2, Tab-1еЗ, .... Таблицы будут соединены таким образом, как mSQL сочтет наиболее эффективным. Именам таблиц могут быть присвоены псевдонимы (например, SELECT t1.name, t2.address FROM Iong_table_name=t1, Ionger_table_name=t2 ). Если не указано выражение clause, SELECT вернет все данные из выбранной таблицы (или таблиц).
Практические задания:
1. Создать таблицу tbl_topics содержащую следующий набор столбцов:
Столбец |
Тип данных |
Диапазон значений |
topic_id |
целочисленный |
0 - 127 |
topic_name |
текстовый |
Не более 100 символов |
Поле topic_id определить как идентификатор и использовать в качестве первичного ключа.
2. Создать таблицу tbl_books для хранения данных о книгах, содержащую следующий набор столбцов:
Столбец |
Тип данных |
Диапазон |
Описание |
b_id |
текстовый |
17 символов |
ISBN код книги |
b_name |
текстовый |
Не более 255 символов.Значения Null не допускаютсяНазвание книги |
|
b_author |
текстовый |
Не более 255 символов |
Автор |
b_topic |
целочисленный |
|
Код категории, к которой относится книга |
b_price |
числовой, точность до 2-х знаков после запятой |
|
Стоимость |
Поле b_id определить как идентификатор и использовать в качестве первичного ключа.
3. Увеличить верхнюю границу диапазона возможных значений в поле topic_id таблицы tbl_tobics до 215-1
4. Добавить в таблицу tbl_topics названия категорий: классика, лирика, мемуары, психология, философия.
5. Добавить несколько строк в таблицу tbl_books.
6. Сделать поле b_id автоинкрементным.
7. Удалить с поля b_id опцию первичного ключа.