Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Інформатика Заоч. Ч.3. 2011 Спиридонов.doc
Скачиваний:
24
Добавлен:
03.03.2016
Размер:
3.74 Mб
Скачать

I. Створення запитів із двох таблиць

Дотепер створювались запити на підставі однієї таблиці. Але, як правило, запити створюються на основі декількох таблиць.

Розглянемо створення запитів з двох таблиць.

По-перше, якщо вибираються поля з різних таблиць, то в іменах полів бажано застосовувати і назву таблиці (яка записується перед ім’ям поля, після чого ставиться крапка) в якій розташовані ці поля. Якщо дві таблиці мають поля з однаковими назвами, то ця рекомендація стає обов’язковою. Інакше система не зможе визначити поле якої таблиці повинне входити у запит.

По-друге, всі таблиці повинні бути зв’язаними деяким чином (не обов’язково, щоби ці зв’язки збігалися з постійними зв’язками, які визначені для таблиць на етапі створення структури бази даних).

У найпростішому випадку зв’язок між двома таблицями встановлюються одним із способів:

FROM Таблиця1 INNER JOIN Таблиця2 ON Таблиця1.поле1= Таблиця2.поле2

FROM Таблиця1 LEFT JOIN Таблиця2 ON Таблиця1.поле1= Таблиця2.поле2

FROM Таблиця1 RIGHT JOIN Таблиця2 ON Таблиця1.поле1= Таблиця2.поле2

Операція INNER JOIN об’єднує записи із двох таблиць таким чином, що до запиту ввійдуть тільки ті записи, для яких пов’язані поля мають однакові значення.

Операція LEFT JOIN об’єднує записи із двох таблиць таким чином, що до запиту ввійдуть всі записи першої таблиці і тільки ті записи другої таблиці, для яких пов’язане поле має відповідні значення із першої таблиці.

Операція RIGHT JOIN об’єднує записи із двох таблиць таким чином, що до запиту ввійдуть всі записи другої таблиці і тільки ті записи першої таблиці, для яких пов’язане поле має відповідні значення із другої таблиці.

Слід відмітити, що зв’язок:

FROM Таблиця1 LEFT JOIN Таблиця2 ON Таблиця1.поле1= Таблиця2.поле2

еквівалентний зв’язку:

FROM Таблиця2 RIGHT JOIN Таблиця1 ON Таблиця1.поле1= Таблиця2.поле2

Умова Таблиця1.поле1= Таблиця2.поле2 є найпростішою умовою зв’язку для двох таблиць. Умова може бути складною і містити в собі декілька простих умов. Але далі будуть розглядатися тільки прості умови зв’язку двох таблиць.

5. Запит 1: Розрахувати загальні суми тільки приходних накладних. Результати вивести у вигляді табл. 2.21.

Таблиця 2.21

Структура таблиці результатів запиту завдання 1

Номнак

СумНак

5.1. Рішення:

Суму для кожної із накладних можна розрахувати, використовуючи таблицю “Спецификация”. Це було зроблено в попередніх завданнях. Для того, щоб зробити розрахунки тільки для приходних накладних, треба разом з таблицею “Спецификация” застосовувати ще й таблицю “ОснСведНак”, яка містить поле “Операція”, значення якого визначає, чи є накладна приходною (значення “+”).

Таблиці “Спецификация” та “ОснСведНак” мають постійний зв’язок по полю “НомНак”. Його доцільно використовувати і для створення запиту за допомогою інструкції SELECT.

Таким чином, маємо:

SELECT Спецификация.НомНак,

Sum(Спецификация.Кол*Спецификация.Цена) AS СумНак

FROM ОснСведНак INNER JOIN Спецификация

ON ОснСведНак.НомНак = Спецификация.НомНак

WHERE ОснСведНак.Операция=+

GROUP BY Спецификация.НомНак;

або

SELECT Спецификация.НомНак, Sum(Кол*Цена) AS СумНак

FROM ОснСведНак INNER JOIN Спецификация

ON ОснСведНак.НомНак = Спецификация.НомНак

WHERE ОснСведНак.Операция=+

GROUP BY Спецификация.НомНак;

5.2. Результат запиту приведений на рис. 20.

Рис. 20. Результат запиту 1

Пояснення: Поля запиту формуються тільки з полів таблиці Специфікація, але для вибору записів перевіряється значення поля ОснСведНак.Операция. Тож у запиті повинно використовувати обидві таблиці, які пов’язані між собою через поле НомНак.

Інструкцію SELECT для виконання поставленного завдання можна переписати в іншому вигляді.

SELECT Спецификация.НомНак, Sum(Кол*Цена) AS СумНак

FROM ОснСведНак INNER JOIN Спецификация

ON ОснСведНак.НомНак = Спецификация.НомНак

GROUP BY Спецификация.НомНак, ОснСведНак.Операция

HAVING ОснСведНак.Операция=+;

Якщо в першій інструкції вибираються записи, які відповідають тільки приходним накладним (умова на записи WHERE ОснСведНак.Операция=“+”), то в другому запиті перевірки записів нема, але записи групуються за двома груповими ознаками (GROUP BY Спецификация.НомНак, ОснСведНак.Операция), після чого встановлюється умова на групу (HAVING ОснСведНак.Операция=“+”). Тобто розрахунок проводиться для всіх встановлених груп, але вибираються тільки ті групи, які відповідають вказаній умові на групу.

5.3. Збережіть створений запит з назвою Запит_14_1.

6. Запит 2: Самостійно створіть інструкцію SELECT для розрахунку сум реалізації товару по покупцях у вигляді: табл. 2.22.

Таблиця 2.22

Структура таблиці результатів запиту 2

Покупець

Сума закупки

6.2. Результат запиту повинен бути таким (рис. 21).

Рис. 21. Результат запиту 2

6.3. Збережіть створений запит з назвою Запит_9_2.

7. Запит 3: Створити інструкцію SELECT для розрахунку сум реалізації товару по покупцях у вигляді табл. 2.23:

Таблиця 2.23

Структура таблиці результатів запиту 3

Товар

Кількість приходу

Результати упорядкувати по назві товару.

7.1. Результат запиту повинен бути таким (рис.22):

Рис. 22. Результат запиту 3

7.3. Збережіть створений запит з назвою Запит_9_3.

8. Результати виконання практичного завдання представте викладачеві для оцінки Вашої роботи.

9. Виконайте завершення роботи.

11. Оформіть дану роботу.