Рисунок 16 - Концептуальная модель учебной базы данных
Проверить результат заполнения таблиц, написав и выполнив простейший запрос:
select * from имя_таблицы
При наличии ошибок выполнить корректировку, исправив либо удалив ошибочные строки таблиц
Контрольные вопросы
1. В каких режимах возможно создание базы данных?
2. Какие типы данных допустимы при создании таблицы?
3. Как выполнить создание таблицы средствами СУБД?
4. Как выполнить создание таблицы средствами языка SQL?
5. Как разделяются операторы SQL в случае нескольких операторов в запросе?
6. Каким образом выполнить простейшие операции вставки строк данных в таблицу средствами SQL?
7. Каким образом выполнить простейшие операции модификации строк таблицы средствами SQL?
8. Каким образом выполнить просмотр таблицы?
9. Как получить информацию о структуре таблицы в рамках СУБД MySQL?
Цель работы: Используя данные базы данных, подготовленной в предыдущей лабораторной работе, подготовить и реализовать серию запросов, связанных с выборкой информации и модификацией данных таблиц.
Содержание работы и методические указания к ее выполнению
1. Изучить набор команд языка SQL, связанный с созданием запросов, добавлением, модификацией и удалением строк таблицы:
select - осуществление запроса по выборке информации из таблиц базы данных;
insert - добавление одной или нескольких строк в таблицу;
delete - удаление одной или нескольких строк из таблицы;
update - модификация одной или нескольких строк таблицы;
union - объединение запросов в один запрос.
2. Изучить состав, правила и порядок использования ключевых фраз оператора select:
select - описание состава данных, которые следует выбрать по запросу (обязательная фраза);
from - описание таблиц, из которых следует выбирать данные (обязательная фраза);
where - описание условий поиска и соединения данных при запросе;
group by - создание одной строки результата для каждой группы (группой называется множество строк, имеющих одинаковые значения в указанных столбцах);
having - наложение одного или более условий на группу;
order by - сортировка результата выполнения запроса по одному или нескольким столбцам;
into outfile - создание файла, в который будет осуществлен вывод результатов соответствующего запроса.
Порядок следования фраз в команде select должен соответствовать приведенной выше последовательности. Для лучшего понимания механизма функционирования выполните следующие упражнения:
I. Простые запросы на языке SQL
Запрос на языке SQL формируется с использованием оператора Select. Оператор Select используется
В общем случае оператор Select содержит следующие семь спецификаторов, расположенных в операторе в следующем порядке:
Обязательными являются только спецификаторы Select и From. Эти два спецификатора составляют основу каждого запроса к базе данных, поскольку они определяют таблицы, из которых выбираются данные, и столбцы, которые требуется выбрать.
Спецификатор Where добавляется для выборки определенных строк или указания условия соединения. Спецификатор Order by добавляется для изменения порядка получаемых данных. Спецификатор Into temp добавляется для сохранения этих результатов в виде таблицы с целью выполнения последующих запросов. Два дополнительных спецификатора оператора Select - Group by (спецификатор группирования) и Having (спецификатор условия выборки группы) - позволяют выполнять более сложные выборки данных.
У п р а ж н е н и я
1. Выбор всех строк и столбцов таблицы.
Пример.
Выдать полную информацию о поставщиках.
Select * from S
Результат: таблица S в полном объеме.
Подготовьте запрос и проверьте полученный результат.
2. Измение порядка следования столбцов.
Пример.
Выдать таблицу S в следующем порядке: фамилия, город, рейтинг, номер_поставщика.
Select фамилия, город, рейтинг, номер_поставщика from S
Результат: таблица S в требуемом порядке.
Подготовьте запрос и проверьте полученный результат.
3. Выбор заданных столбцов.
Пример.
Выдать номера всех поставляемых деталей.
Select номер_детали from SPJ
Результат: столбец номер_детали таблицы SPJ
Подготовьте запрос и проверьте полученный результат.
4. Выбор без повторения.
Пример.
Выдать номера всех поставляемых деталей, исключая дублирование.
Select distinct номер_детали from SPJ
Результат: | номер_детали |
P1 | |
P2 | |
P3 | |
P4 | |
P5 | |
P6 |
Подготовьте запрос и проверьте полученный результат.
5. Использование в запросах констант и выражений.
Пример.
Select номер_детали, "вес в граммах", вес*454 from P
Результат: | P1 вес в граммах=5448 |
--------------------- | |
--------------------- | |
P6 вес в граммах=8226 |
Подготовьте запрос и проверьте полученный результат.
6.Ограничение в выборке.
Пример.
Выдать номера всех поставщиков, находящихся в Париже с рейтингом > 20.
Select номер_поставщика from S where город="Париж" and рейтинг>20
Результат: | номер_поставщика |
S3 |
Подготовьте запрос и проверьте полученный результат.
7. Выборка с упорядочиванием.
Пример.
Выдать номера поставщиков, находящихся в Париже в порядке убывания рейтинга.
Select номер_поставщика, рейтинг from S where город="Париж" order by рейтинг desc
Результат: | номер_поставщика | рейтинг |
S3 | 30 | |
S2 | 10 |
Подготовьте запрос и проверьте полученный результат.
8. Упорядочивание по нескольким столбцам.
Пример.
Выдать список поставщиков, упорядоченных по городу, в пределах города - по рейтингу.
Select * from S order by 4, 3
Результат: | Hомеp_поставщика | Фамилия | Рейтинг | Гоpод |
S5 | Адамс | 30 | Атенс | |
S1 | Смит | 20 | Лондон | |
S4 | Кларк | 20 | Лондон | |
S2 | Джонс | 10 | Париж | |
S3 | Блейк | 30 | Париж |
Подготовьте запрос и проверьте полученный результат.
9. Фраза in ( not in ).
Пример.
Выдать детали, вес которых равен 12, 16 или 17.
Select номер_детали, название, вес from P where вес in (12, 16, 17)
Результат: | номер_детали | Название | вес |
P1 | Гайка | 12 | |
P2 | Болт | 17 | |
P3 | Винт | 17 | |
P5 | Кулачок | 12 |
Подготовьте запрос и проверьте полученный результат.
12. Выбор по шаблону.
Для запросов с поиском по шаблону, основанных на поиске подстрок в полях типа CHARACTER, используются ключевое слова LIKE.
Включение в выражение ключевого слова NOT порождает условие c обратным смыслом. Ключевое слово LIKE соответствует стандарту ANSI.
СИМВОЛ | ЗНАЧЕНИЕ |
LIKE | |
% | Заменяет последовательность символов |
- | Заменяет любой одиночный символ |
\ | Отменяет специальное назначение следующего за ним символа |
Примеры.
а) Выбрать список деталей, начинающихся с буквы "Б"[10]
Select номер_детали, название, вес from P where название like "Б%"
Результат: | номер_детали | название | вес |
P5 | Болт | 12 | |
P6 | Блюм | 19 |
II. Использование функций