71753

Изменение таблицы. Выбор данных из таблиц

Лабораторная работа

Информатика, кибернетика и программирование

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

Русский

2014-11-11

53 KB

0 чел.

Лабораторная работа №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). Если значение выходит за пределы нового типа, используется максимально возможное значение нового типа данных (или наименьшее из отрицательных).

  •  Числовых к текстовым (например, SMALLINT к CHAR(5)).
  •  Текстовых к числовым (например, VARCHAR к MEDIUMINT). Текст преобразуется либо в целое число, либо в число с плавающей запятой. (Что более подходит для нового типа.)
  •  Меньших символьных типов к большим (например, BLOB к LONG-TEXT).
  •  Больших символьных типов к меньшим (например, TEXT к VARCHAR (255) ). Если значение больше, чем позволяет новый тип данных, текст усекается для соответствия этому типу.
  •  Даже для преобразований, которые здесь не упомянуты (например, TIMESTAMP к YEAR), MySQL попытается сделать все возможное, чтобы совершить разумное преобразование. При использовании CHANGE преобразование будет выполнено в любом случае, ни при каких обстоятельствах MySQL не сдастся и не выдаст сообщения об ошибке. Помня об этом, вы должны (1) сделать резервную копию данных перед преобразованием и (2) немедленно проверить новые значения на «разумность».

Примеры

# Добавить поле 'address2' к таблице 'people' и. задать ему тип данных

# 'VARCHAR' с максимальной длиной 200 символов.

  •  ALTER TABLE people ADD COLUMN address2 VARCHAR(100)

# Добавить два новых индекса к таблице 'hr', обычный индекс для поля

# 'salary'

# и уникальный индекс для поля 'id'. Также продолжить выполнение, если

# найдены

# дублируемые значения при создании индекса 'id_idx' (очень опасно!).

  •  ALTER TABLE hr ADD INDEX salary_idx ( salary )
  •  ALTER IGNORE TABLE hr ADD UNIQUE id_idx ( id )

# Изменить значение по умолчанию для поля 'price' в таблице 'sprockets'

# на $19.95.

  •  ALTER TABLE sprockets ALTER price SET DEFAULT '$19.95'

# Удалить значение по умолчанию для поля 'middle_name' в таблице 'names'.

  •  ALTER TABLE names ALTER middle_name DROP DEFAULT

# Изменить тип данных для поля 'profits' с начального значения (которым,

# возможно, было INTEGER) на BIGINT.

  •  ALTER TABLE finanaces CHANGE COLUMN profits profits BIGINT

# Удалить поле 'secret_stuff' из таблицы 'not_private_anymore'

  •  ALTER TABLE not_private_anymore DROP secret_stuff

# удалить индекс с именем 'id_index' также как и первичный ключ

# из таблицы 'cars'.

  •  ALTER TABLE cars DROP INDEX id_index, DROP PRIMARY KEY

# Переименовать таблицу 'rates_current' на 'rates_1997'

  •  ALTER TABLE rates_current RENAME AS rates_1997

SELECT

  •  SELECT [DISTINCT] columns FROM table [clause]

Выбирает данные из таблицы. Оператор 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 опцию первичного ключа.


 

А также другие работы, которые могут Вас заинтересовать

46058. Оценка эффективности PR-кампании 44 KB
  Планирование PRмероприятия дает возможность проведения оценки эффективности. Оценка эффективности это всегда сравнение достигнутых результатов с планируемыми поэтому прежде всего необходимо определить стратегическую цель и тактические задачи проводимой PRдеятельности. Оценка эффективности PRкампании всегда напрямую связана с ее планированием так как это позволяет уже на этапе подготовки любой PRактивности...
46059. Уравнения движения механизма 479.5 KB
  Выполнив приведение сил и масс, любой механизм с одной степенью свободы (рычажный, зубчатый, кулачковый и др.), сколь бы сложным он ни был, можно заменить его динамической моделью...
46060. Кинематика и динамика вращательного движения АТТ 500.5 KB
  Кинематические характеристики частицы (поступательного движения АТТ) – перемещение , скорость и ускорение не могут служить характеристиками АТТ, участвующего во вращательном движении (для разных точек АТТ они разные). Нужны другие характеристики.
46061. Ламбдацизм. Определение, этиология, виды. Логопедические технологии устранения ламбдацизма у детей 30.5 KB
  Во время правильного произнесения звука л органы речи принимают следующее положение: губы раскрыты занимают нейтральное положение или принимают положение последующего гласного звука; зубы незначительно разомкнуты; язык узкий кончик языка поднимается и упирается в верхние резцы или их десны средняя часть языка опущена боковые края тоже опущены; между боковыми краями языка и коренными зубами остается щель через которую выходит воздушная струя.Артикуляция твердого звука л сложнее артикуляции ль поэтому нарушение его произношения...
46062. Ротацизм. Определение, этиология, виды. Логопедические технологии устранения ротацизма у детей 36.5 KB
  Причины нарушения звуков р и рь: укороченная подъязычная связка уздечка ограничивающая движение вверх кончика языка и передней части спинки языка; слабость мышц языка; неумение выполнять языком произвольные целенаправленные движения; нарушения фонематического слуха.Звук р согласныйвоздушная струя встречает преграду;язычный переднеязычный передненебный передняя часть языка направляется к передней части неба;смычный дрожащий вибрант образуется путем вибрации кончика языка смыкании и размыкании его около альвеол;сонорный...
46063. Каппацизм и йотацизм. Определение, этиология, виды. Логопедические технологии устранения каппацизма и йотацизма. Каппацизм – дефект произношения нёбных звуков к, к 18.5 KB
  Кончик языка опущен но не прикасается к нижним зубам. Корень языка поднят и смыкается с небом.Предложите ребенку произносить слоги татата и одновременно с этим нажимайте шпателем или плоским концом ложечки на кончик языка отодвигайте язык отт нижних зубов глубь рта. Таким образом спинка языка все больше выгибается и соответственно получается тятятя потом кякякя и наконец когда происходит смычка спинки языка с небом должно получиться какака.
46064. Нарушение звукопроизношения по звонкости – глухости, твёрдости – мягкости. Логопедические технологии устранения этих дефектов 32 KB
  Исправление данного недостатка следует начинать со щелевых звуков в з жА потом квзрывным б д г. громкое ишёпотное произнесение гласных звуков отрывисто и длительно. Озвончение щелевых звуков не всегда удаётся вызвать сразу это связано с тем что как правило в этих случаях есть какой то вид сигматизма. При этом он обращает внимание ребенка не только на различие в звучании звуков но и на то что в момент произнесения твердого звука в можно прикоснувшись рукой к гортани ощущать её вибрацию.
46065. Игры в логопедической работе с детьми. Системы игр, анализ методической литературы 15 KB
  Игры в логопедической работе с детьми. Игры используют в любые режимные моменты как на занятиях так и вне. Подготовительный этап: игры на развитие всех психических функций. Далее игры на развитие артикуляционной моторики.
46066. Личность логопеда. Сферы деятельности логопеда, функциональные обязанности, профессионально значимые качества. Организация логопедической помощи населению России 36 KB
  Логопед должен уметь распознавать речевые нарушения владеть приёмами и методами их устранения и коррекции специальными методами обучения детей с речевыми расстройствами родному языку как в дошкольном так и в школьном возрасте проводить профилактическую работу по предупреждению неуспеваемости хорошо знать психологические особенности детей с речевой патологией использовать приемы и методы их воспитания корреляции и развития у них высших корковых функций. Первостепенное значение для эффективности работы по обучению воспитанию...