<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>https://iu5bmstu.ru/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=195.19.50.70</id>
	<title>Кафедра ИУ5 МГТУ им. Н.Э.Баумана, студенческое сообщество - Вклад [ru]</title>
	<link rel="self" type="application/atom+xml" href="https://iu5bmstu.ru/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=195.19.50.70"/>
	<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%A1%D0%BB%D1%83%D0%B6%D0%B5%D0%B1%D0%BD%D0%B0%D1%8F:%D0%92%D0%BA%D0%BB%D0%B0%D0%B4/195.19.50.70"/>
	<updated>2026-04-30T21:24:25Z</updated>
	<subtitle>Вклад</subtitle>
	<generator>MediaWiki 1.41.0</generator>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=SQL-%D0%B7%D0%B0%D0%BF%D1%80%D0%BE%D1%81%D1%8B_%D0%BA_%D1%8D%D0%BA%D0%B7%D0%B0%D0%BC%D0%B5%D0%BD%D1%83_%D0%BF%D0%BE_%D0%A1%D0%9F%D0%90%D0%A1%D0%9E%D0%98_(10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=3909</id>
		<title>SQL-запросы к экзамену по СПАСОИ (10 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=SQL-%D0%B7%D0%B0%D0%BF%D1%80%D0%BE%D1%81%D1%8B_%D0%BA_%D1%8D%D0%BA%D0%B7%D0%B0%D0%BC%D0%B5%D0%BD%D1%83_%D0%BF%D0%BE_%D0%A1%D0%9F%D0%90%D0%A1%D0%9E%D0%98_(10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=3909"/>
		<updated>2013-06-20T18:23:07Z</updated>

		<summary type="html">&lt;p&gt;195.19.50.70: /* Про JOIN */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;div style=&amp;quot;float:right; clear:both; margin-right:1.0em;&amp;quot;&amp;gt;__TOC__&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Билет экзамена по [[:Категория:Структурное проектирование АСОИ (10 семестр) | СПАСОИ]] состоит из двух частей:&lt;br /&gt;
# теория;&lt;br /&gt;
# SQL-запрос.&lt;br /&gt;
&lt;br /&gt;
На этой странице собраны все сформированные запросы по билетам.&lt;br /&gt;
&lt;br /&gt;
Странно, что ни в одном билете нет запроса с сортировкой результатов. &amp;lt;s&amp;gt;Возможно, они буду в дополнительных заданиях.&amp;lt;/s&amp;gt; Григорьев сказал, что это слишком просто и потому он не стал загромождать запросы дополнительными мелочами.&lt;br /&gt;
&lt;br /&gt;
== Схема БД ==&lt;br /&gt;
&lt;br /&gt;
Схема БД используется всё [[СПАСОИ_(10)_-_Лекция_№8_-_SQL#Некоторые возможности языка SQL | та же]], что была в прошлом семестре и на лекциях.&lt;br /&gt;
&lt;br /&gt;
Для написания запросов и проверки их выполнения создана БД в СУБД [http://www.postgresql.org/ PostgreSQL].&lt;br /&gt;
&lt;br /&gt;
Скрипт создания можно загрузить [http://yadi.sk/d/ArwqOGAy5pPfi отсюда].&lt;br /&gt;
&lt;br /&gt;
=== Таблицы БД ===&lt;br /&gt;
&lt;br /&gt;
==== Поставщики ====&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT * FROM spasoi_ekz.s;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika |       imya       | sostoyanie |   gorod&lt;br /&gt;
 -------------------+------------------+------------+------------&lt;br /&gt;
  S5                | Мелисандра       |      65000 | Мадрид&lt;br /&gt;
  S2                | Бран Старк       |      60000 | Мурманск&lt;br /&gt;
  S1                | Якен Хгар        |    1500000 | Йокогама&lt;br /&gt;
  S7                | Сирио Форель     |    1500000 | Йокогама&lt;br /&gt;
  S4                | Джейме Ланнистер |     750000 | Лондон&lt;br /&gt;
  S3                | Серсея Ланнистер |    1200000 | Лондон&lt;br /&gt;
  S8                | Тирион Ланнистер |       2571 | Манчестер&lt;br /&gt;
  S9                | Иванов           |      35000 | Мытищи&lt;br /&gt;
  S10               | Русе Болтон      |      44444 | Баренцбург&lt;br /&gt;
  S11               | Петров Иван      |      35000 | Мытищи&lt;br /&gt;
  S14               | Рендилл Тарли    |    1111111 | Прага&lt;br /&gt;
  S13               | Сэмвелл Тарли    |     999999 | Прага&lt;br /&gt;
  S6                | Оша              |            | Москва&lt;br /&gt;
  S16               | Ходор            |            | Москва&lt;br /&gt;
  S15               | Мелисса Флорент  |     888888 | Стокгольм&lt;br /&gt;
  S12               | Петров Пётр      |      35001 | Мытищи&lt;br /&gt;
  S17               | Томми Версетти   |  123456789 | Майами&lt;br /&gt;
  S18               | Безликий         |          1 | Йокогама&lt;br /&gt;
 (18 rows)&lt;br /&gt;
&lt;br /&gt;
==== Детали ====&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT * FROM spasoi_ekz.p;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  nomer_detali |       nazvanie       |     cvet      | ves  |      gorod&lt;br /&gt;
 --------------+----------------------+---------------+------+-----------------&lt;br /&gt;
  P9           | подставка            | синий         |  400 | Нижний Новгород&lt;br /&gt;
  P10          | стойка               | синий         | 2000 | Нижний Новгород&lt;br /&gt;
  P11          | абажур               | синий         |  400 | Нижний Новгород&lt;br /&gt;
  P1           | гайка                | чёрный        |   20 | Лондон&lt;br /&gt;
  P3           | ось                  | белый         | 5000 | Эдинбург&lt;br /&gt;
  P4           | зубчатое колесо      | чёрный        |   50 | Эдинбург&lt;br /&gt;
  P6           | транзистор           | коричневый    |    2 | Токио&lt;br /&gt;
  P7           | печатная плата       | зелёный       |  200 | Токио&lt;br /&gt;
  P8           | диод                 | коричневый    |    1 | Токио&lt;br /&gt;
  P12          | универсальная деталь | универсальный |    1 | Париж&lt;br /&gt;
  P13          | уникальная деталь    | уникальный    |    1 | Бостон&lt;br /&gt;
  P14          | болт                 | серый         |   20 | Ижевск&lt;br /&gt;
  P15          | рама                 | красный       | 3000 | Манчестер&lt;br /&gt;
  P16          | колесо               | белый         | 1500 | Манчестер&lt;br /&gt;
  P5           | втулка               | серый         |  350 | Манчестер&lt;br /&gt;
  P17          | бумага               | белый         |    1 | Астрахань&lt;br /&gt;
  P18          | плитка               | белый         |  300 | Флоренция&lt;br /&gt;
  P19          | орнамент             | серый         |  800 | Флоренция&lt;br /&gt;
  P20          | уголок               | серый         |  100 | Флоренция&lt;br /&gt;
  P21          | гайка 01-01          | серебристый   |   20 | Клин&lt;br /&gt;
  P22          | усиленная рама       | красный       | 3200 | Череповец&lt;br /&gt;
  P23          | винт                 | розовый       |    5 | Ижевск&lt;br /&gt;
  P24          | труселя              | красный       |   20 | Челябинск&lt;br /&gt;
  P25          | штуцерная деталь     | коричневый    |  450 | Череповец&lt;br /&gt;
  P2           | шуруп                | чёрный        |    5 | Лондон&lt;br /&gt;
  P26          | лезвие               | бесцветный    |  120 | Йокогама&lt;br /&gt;
 (26 rows)&lt;br /&gt;
&lt;br /&gt;
==== Изделия ====&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT * FROM spasoi_ekz.j;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  nomer_izdelia |       nazvanie        |      gorod&lt;br /&gt;
 ---------------+-----------------------+-----------------&lt;br /&gt;
  J1            | автомобиль            | Магнитогорск&lt;br /&gt;
  J2            | процессор             | Зеленоград&lt;br /&gt;
  J3            | торшер                | Нижний Новгород&lt;br /&gt;
  J4            | универсальное изделие | Париж&lt;br /&gt;
  J5            | уникальное изделие    | Бостон&lt;br /&gt;
  J6            | велосипед 01/23       | Манчестер&lt;br /&gt;
  J7            | изделие из болтов     | Челябинск&lt;br /&gt;
  J8            | шкаф                  | Ярославль&lt;br /&gt;
  J9            | рама 02-01            | Череповец&lt;br /&gt;
  J10           | книга                 | Астрахань&lt;br /&gt;
  J11           | панно 01-03           | Флоренция&lt;br /&gt;
  J12           | велосипед 03-04       | Клин&lt;br /&gt;
  J13           | рама 02-03            | Череповец&lt;br /&gt;
  J14           | штуцер 01-02          | Череповец&lt;br /&gt;
  J15           | велосипед 01-04       | Клин&lt;br /&gt;
  J16           | кружевное бельё       | Челябинск&lt;br /&gt;
  J17           | штуцер 01-03          | Череповец&lt;br /&gt;
  J18           | кинжал                | Йокогама&lt;br /&gt;
 (18 rows)&lt;br /&gt;
&lt;br /&gt;
==== Сборки ====&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT * FROM spasoi_ekz.spj;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika | nomer_detali | nomer_izdelia | kolichestvo&lt;br /&gt;
 -------------------+--------------+---------------+-------------&lt;br /&gt;
  S1                | P6           | J2            |          20&lt;br /&gt;
  S1                | P7           | J2            |           5&lt;br /&gt;
  S2                | P1           | J1            |           4&lt;br /&gt;
  S6                | P4           | J1            |           2&lt;br /&gt;
  S6                | P5           | J1            |           6&lt;br /&gt;
  S3                | P9           | J3            |           1&lt;br /&gt;
  S4                | P10          | J3            |           1&lt;br /&gt;
  S5                | P11          | J3            |           1&lt;br /&gt;
  S2                | P4           | J1            |           8&lt;br /&gt;
  S6                | P3           | J1            |          50&lt;br /&gt;
  S7                | P8           | J2            |          25&lt;br /&gt;
  S1                | P12          | J4            |           1&lt;br /&gt;
  S2                | P12          | J4            |           1&lt;br /&gt;
  S3                | P12          | J4            |           1&lt;br /&gt;
  S4                | P12          | J4            |           1&lt;br /&gt;
  S5                | P12          | J4            |           1&lt;br /&gt;
  S7                | P12          | J4            |           1&lt;br /&gt;
  S7                | P2           | J1            |           1&lt;br /&gt;
  S6                | P2           | J1            |           9&lt;br /&gt;
  S6                | P12          | J4            |           7&lt;br /&gt;
  S1                | P13          | J5            |          14&lt;br /&gt;
  S6                | P14          | J1            |        9000&lt;br /&gt;
  S2                | P14          | J1            |           3&lt;br /&gt;
  S6                | P1           | J1            |          12&lt;br /&gt;
  S8                | P15          | J6            |           1&lt;br /&gt;
  S8                | P16          | J6            |           2&lt;br /&gt;
  S3                | P5           | J6            |          10&lt;br /&gt;
  S10               | P2           | J8            |           4&lt;br /&gt;
  S8                | P1           | J7            |          16&lt;br /&gt;
  S9                | P14          | J7            |           3&lt;br /&gt;
  S11               | P10          | J3            |           2&lt;br /&gt;
  S12               | P15          | J1            |           3&lt;br /&gt;
  S11               | P11          | J3            |           4&lt;br /&gt;
  S10               | P14          | J9            |           5&lt;br /&gt;
  S13               | P17          | J10           |        1001&lt;br /&gt;
  S14               | P17          | J10           |        1111&lt;br /&gt;
  S15               | P17          | J10           |        1010&lt;br /&gt;
  S5                | P18          | J11           |           9&lt;br /&gt;
  S5                | P19          | J11           |           1&lt;br /&gt;
  S5                | P20          | J11           |           4&lt;br /&gt;
  S9                | P14          | J8            |          25&lt;br /&gt;
  S12               | P21          | J12           |          15&lt;br /&gt;
  S11               | P22          | J13           |           9&lt;br /&gt;
  S11               | P1           | J14           |          26&lt;br /&gt;
  S12               | P1           | J14           |          13&lt;br /&gt;
  S12               | P2           | J14           |          54&lt;br /&gt;
  S12               | P23          | J4            |         101&lt;br /&gt;
  S12               | P16          | J15           |          40&lt;br /&gt;
  S7                | P21          | J12           |           3&lt;br /&gt;
  S8                | P21          | J12           |           4&lt;br /&gt;
  S9                | P21          | J12           |           5&lt;br /&gt;
  S1                | P24          | J16           |           1&lt;br /&gt;
  S1                | P15          | J6            |           3&lt;br /&gt;
  S4                | P25          | J17           |           1&lt;br /&gt;
  S17               | P16          | J1            |           4&lt;br /&gt;
  S18               | P26          | J18           |           1&lt;br /&gt;
 (56 rows)&lt;br /&gt;
&lt;br /&gt;
== Готовые запросы ==&lt;br /&gt;
&lt;br /&gt;
=== Некоторое вступление ===&lt;br /&gt;
&lt;br /&gt;
Если видите, что тот или иной запрос можно составить короче и рациональней - смело вносите правку.&lt;br /&gt;
&lt;br /&gt;
==== Про только и только ====&lt;br /&gt;
&lt;br /&gt;
В трёх билетах в задании на запрос встречается формулировка &amp;quot;&#039;&#039;только и только&#039;&#039;&amp;quot;. Как оказалось, это означает следующее: если холодильники поставляет &#039;&#039;только и только&#039;&#039; Уася, то:&lt;br /&gt;
# кроме Уаси никто не поставляет холодильники;&lt;br /&gt;
# Уася не поставляет ничего, кроме холодильников.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;s&amp;gt;Великий и могучий русский языка, ну что за экономия на бумаге.&amp;lt;/s&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Существующие запросы, естественно, оказались неправильными и их пришлось переписать.&lt;br /&gt;
&lt;br /&gt;
==== Про JOIN ====&lt;br /&gt;
&lt;br /&gt;
Почти все запросы, где используется соединение таблиц, можно написать с использованием &amp;lt;code&amp;gt;JOIN&amp;lt;/code&amp;gt;, а можно просто с перечислением таблиц через запятую.&lt;br /&gt;
&lt;br /&gt;
Но неожиданно оказалось, это почти то же самое и называется [http://ru.wikipedia.org/wiki/Join_%28SQL%29#CROSS_JOIN CROSS JOIN]. Такое соединение таблиц (&amp;lt;code&amp;gt;CROSS JOIN + WHERE&amp;lt;/code&amp;gt;) считается устаревшим, поскольку его не рекомендует стандарт SQL ANSI. Таким образом, использование &amp;lt;code&amp;gt;JOIN&amp;lt;/code&amp;gt; с условием соединения в &amp;lt;code&amp;gt;ON&amp;lt;/code&amp;gt; является &amp;lt;s&amp;gt;хипстерством в программировании&amp;lt;/s&amp;gt; более правильным и вообще прогрессивным.&lt;br /&gt;
&lt;br /&gt;
=== Билет 1 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj SPJX&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = SPJX.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
  S2&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 2 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, поставляемых более чем одним поставщиком.&lt;br /&gt;
&lt;br /&gt;
Текст запроса, каким его дал Григорьев на лекции, впоследствии исправив его:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       SUM(kolichestvo) AS &amp;quot;Сколько штук поставляется&amp;quot;,&lt;br /&gt;
       COUNT(DISTINCT nomer_postavshika) AS &amp;quot;Сколько у неё поставщиков&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       kol AS &amp;quot;Сколько штук поставляется&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT nomer_detali,&lt;br /&gt;
             SUM(kolichestvo) AS kol,&lt;br /&gt;
             COUNT(DISTINCT nomer_postavshika)&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1&lt;br /&gt;
     ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Сколько штук поставляется | Сколько у неё поставщиков&lt;br /&gt;
 --------------+---------------------------+---------------------------&lt;br /&gt;
  P1           |                        71 |                         5&lt;br /&gt;
  P10          |                         3 |                         2&lt;br /&gt;
  P11          |                         5 |                         2&lt;br /&gt;
  P12          |                        13 |                         7&lt;br /&gt;
  P14          |                      9036 |                         4&lt;br /&gt;
  P15          |                         7 |                         3&lt;br /&gt;
  P16          |                        46 |                         3&lt;br /&gt;
  P17          |                      3122 |                         3&lt;br /&gt;
  P2           |                        68 |                         4&lt;br /&gt;
  P21          |                        27 |                         4&lt;br /&gt;
  P4           |                        10 |                         2&lt;br /&gt;
  P5           |                        16 |                         2&lt;br /&gt;
 (12 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 3 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, поставляющих детали с номером &#039;P1&#039; для какого-либо изделия в количестве (в поставке) большим, чем средний объём поставок деталей с номером &#039;P2&#039; для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT X.nomer_postavshika &lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE X.nomer_detali = &#039;P1&#039;&lt;br /&gt;
  AND X.kolichestvo &amp;gt; (&lt;br /&gt;
                       SELECT AVG(kolichestvo)&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                         AND nomer_detali = &#039;P2&#039;&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT *&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      WHERE nomer_izdelia IN(&lt;br /&gt;
                             SELECT nomer_izdelia&lt;br /&gt;
                             FROM spasoi_ekz.spj&lt;br /&gt;
                             WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                            )&lt;br /&gt;
        AND nomer_izdelia IN(&lt;br /&gt;
	                     SELECT nomer_izdelia&lt;br /&gt;
	                     FROM spasoi_ekz.spj&lt;br /&gt;
	                     WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
	                    )&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE nomer_detali = &#039;P1&#039; AND kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM (&lt;br /&gt;
       SELECT *&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       WHERE nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                             )&lt;br /&gt;
         AND nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
                             )&lt;br /&gt;
      ) B&lt;br /&gt;
 WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 4 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий, для которых детали поставляет только поставщик с номером ‘S1’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                    AND X.nomer_izdelia = nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE nomer_izdelia IN(&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                      )&lt;br /&gt;
  AND nomer_izdelia NOT IN(&lt;br /&gt;
                           SELECT nomer_izdelia&lt;br /&gt;
                           FROM spasoi_ekz.spj&lt;br /&gt;
                           WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                          );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_izdelia&lt;br /&gt;
 ---------------&lt;br /&gt;
  J5&lt;br /&gt;
  J16&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 5 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &amp;quot;Болт&amp;quot; в количестве (в поставке) большим, чем средний объём всех поставок деталей с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                           ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                           ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                              AND nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Вариант запроса без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
  AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
  AND SPJ.kolichestvo &amp;gt; (&lt;br /&gt;
                         SELECT AVG(kolichestvo)&lt;br /&gt;
                         FROM spasoi_ekz.spj&lt;br /&gt;
                         WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                        );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант запроса без JOIN и сложнее&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika IN (&lt;br /&gt;
                            SELECT nomer_postavshika&lt;br /&gt;
                            FROM spasoi_ekz.spj&lt;br /&gt;
                            WHERE nomer_detali = (&lt;br /&gt;
                                                  SELECT nomer_detali&lt;br /&gt;
                                                  FROM spasoi_ekz.p&lt;br /&gt;
                                                  WHERE LOWER(nazvanie) = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                                                 )&lt;br /&gt;
                              AND kolichestvo &amp;gt; (&lt;br /&gt;
                                                 SELECT AVG(kolichestvo)&lt;br /&gt;
                                                 FROM spasoi_ekz.spj&lt;br /&gt;
                                                 WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                                                )&lt;br /&gt;
                           );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------&lt;br /&gt;
  Оша&lt;br /&gt;
  Иванов&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 6 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, поставляемых поставщиком, проживающим в том же городе, где изготавливаются эти детали, для изделия с названием ‘Велосипед 01/23’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01/23&#039;);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.S S, spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
  AND nomer_izdelia = (&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.j&lt;br /&gt;
                       WHERE nazvanie = LOWER(&#039;Велосипед 01/23&#039;)&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie&lt;br /&gt;
 ----------&lt;br /&gt;
  рама&lt;br /&gt;
  колесо&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 7 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входят детали с названием &#039;Болт&#039;, поставляемых поставщиками с именем &#039;Иванов&#039;, в количестве (в поставке) большим, чем средний объём поставок для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj X&lt;br /&gt;
                     WHERE SPJ.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j&lt;br /&gt;
WHERE nomer_izdelia IN (&lt;br /&gt;
                        SELECT nomer_izdelia&lt;br /&gt;
                        FROM (spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                                      AND imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                                                 JOIN spasoi_ekz.p P&lt;br /&gt;
                                                   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                      AND nazvanie = LOWER(&#039;Болт&#039;)) A&lt;br /&gt;
                        WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                                             SELECT AVG(kolichestvo)&lt;br /&gt;
                                             FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                                       ON SPJ.nomer_izdelia = A.nomer_izdelia&lt;br /&gt;
                                            )&lt;br /&gt;
                       );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант этого же запроса, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT J.nazvanie, kolichestvo&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
        AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
        AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
        AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
        AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM spasoi_ekz.spj&lt;br /&gt;
 WHERE nomer_izdelia IN(&lt;br /&gt;
                        SELECT J.nomer_izdelia&lt;br /&gt;
                        FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
                        WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                          AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                          AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                          AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                          AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                       )&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 -------------------&lt;br /&gt;
  шкаф&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 8 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий и общее количество деталей для них, поставляемых поставщиками с именем &#039;Петров&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia AS &amp;quot;Номер изделия&amp;quot;, SUM(kolichestvo) AS &amp;quot;Количество деталей&amp;quot; &lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                             -- так как &amp;quot;поставщикАМИ&amp;quot; и возможны&lt;br /&gt;
                             -- Иван Петров и Петров Иван, то LIKE %Петров%&lt;br /&gt;
                             AND imya LIKE &#039;%Петров%&#039;&lt;br /&gt;
GROUP BY nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер изделия | Количество деталей&lt;br /&gt;
 ---------------+--------------------&lt;br /&gt;
  J4            |                101&lt;br /&gt;
  J3            |                  6&lt;br /&gt;
  J13           |                  9&lt;br /&gt;
  J15           |                 40&lt;br /&gt;
  J1            |                  3&lt;br /&gt;
  J12           |                 15&lt;br /&gt;
  J14           |                 93&lt;br /&gt;
 (7 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 9 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, которые входят только в одно изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, kol FROM (&lt;br /&gt;
       SELECT nomer_detali, SUM(kolichestvo) AS kol, COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
    ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali | sum&lt;br /&gt;
 --------------+------&lt;br /&gt;
  P10          |    3&lt;br /&gt;
  P11          |    5&lt;br /&gt;
  P12          |   13&lt;br /&gt;
  P13          |   14&lt;br /&gt;
  P17          | 3122&lt;br /&gt;
  P18          |    9&lt;br /&gt;
  P19          |    1&lt;br /&gt;
  P20          |    4&lt;br /&gt;
  P21          |   27&lt;br /&gt;
  P22          |    9&lt;br /&gt;
  P23          |  101&lt;br /&gt;
  P24          |    1&lt;br /&gt;
  P25          |    1&lt;br /&gt;
  P26          |    1&lt;br /&gt;
  P3           |   50&lt;br /&gt;
  P4           |   10&lt;br /&gt;
  P6           |   20&lt;br /&gt;
  P7           |    5&lt;br /&gt;
  P8           |   25&lt;br /&gt;
  P9           |    1&lt;br /&gt;
 (20 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 10 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &#039;Болт&#039; для изделия с названием &#039;Рама 02-01&#039; в количестве (в поставке) большим, чем минимальное значение поставки детали с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
			   ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			      AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.p P&lt;br /&gt;
			   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
			      AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.s S&lt;br /&gt;
			   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
		     SELECT MIN(kolichestvo)&lt;br /&gt;
		     FROM spasoi_ekz.spj &lt;br /&gt;
		     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Русе Болтон&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 11 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия городов и суммарное состояние проживающих в каждом городе поставщиков, у которых минимальный объём поставки деталей больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ &lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
GROUP BY gorod HAVING MIN(kolichestvo) &amp;gt; 1000;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант этого запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE (	&lt;br /&gt;
       SELECT MIN(kolichestvo)	&lt;br /&gt;
       FROM spasoi_ekz.spj X	&lt;br /&gt;
       WHERE X.nomer_postavshika = S.nomer_postavshika		&lt;br /&gt;
      ) &amp;gt; 1000&lt;br /&gt;
GROUP BY gorod;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант подлиннее для тех, кто не ищет лёгких путей&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika IN (&lt;br /&gt;
                            SELECT nomer_postavshika&lt;br /&gt;
                            FROM spasoi_ekz.spj&lt;br /&gt;
                            GROUP BY nomer_postavshika HAVING MIN(kolichestvo) &amp;gt; 1000&lt;br /&gt;
                           )&lt;br /&gt;
GROUP BY gorod;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;!-- а этот запрос выполняет не совсем то и не правильно&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, sost&lt;br /&gt;
FROM (&lt;br /&gt;
SELECT gorod, SUM(sostoyanie) AS sost, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj, spasoi_ekz.s&lt;br /&gt;
WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
GROUP BY S.gorod HAVING SUM(SPJ.kolichestvo) &amp;gt; 1000&lt;br /&gt;
) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt; &lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    gorod   |   sum&lt;br /&gt;
 -----------+---------&lt;br /&gt;
  Прага     | 2111110&lt;br /&gt;
  Стокгольм |  888888&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 12 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей, поставляемых для какого-либо изделия поставщиком, проживающим в том же городе, где изготавливается это изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali&lt;br /&gt;
FROM spasoi_ekz.spj SPJ, spasoi_ekz.s S, spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND S.gorod = J.gorod&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali&lt;br /&gt;
 --------------&lt;br /&gt;
  P15&lt;br /&gt;
  P16&lt;br /&gt;
  P26&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 13 ===&lt;br /&gt;
&lt;br /&gt;
Написать &amp;lt;u&amp;gt;один&amp;lt;/u&amp;gt; запрос SELECT: выдать количества строк в таблице S (Поставщик) 1) с пустыми значениями и 2) непустыми значениями в столбце Состояние.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT COUNT(*) - COUNT(sostoyanie) AS &amp;quot;С пустым состоянием&amp;quot;, &lt;br /&gt;
       COUNT(sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SELECT COUNT(Snull.*) AS &amp;quot;С пустым состоянием&amp;quot;, COUNT(Snotnull.sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s Snull RIGHT OUTER JOIN spasoi_ekz.s Snotnull&lt;br /&gt;
                                      ON Snull.nomer_postavshika = Snotnull.nomer_postavshika&lt;br /&gt;
                                         AND Snull.sostoyanie IS NULL;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  С пустым состоянием | С не пустым состоянием&lt;br /&gt;
 ---------------------+-----------------------&lt;br /&gt;
                    2 |                    16&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 14 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют детали только и только для изделия с номером &#039;J1&#039;.&lt;br /&gt;
&lt;br /&gt;
Чтобы продемонстрировать выполнение запроса наглядно, возьмём изделие не &#039;J1&#039;, а &#039;J18&#039;, которое было создано специально для этого запроса. Если оставить &#039;J1&#039;, то наглядности не получится, так как по нашей схеме БД это изделие не попадает под условие &amp;quot;только и только&amp;quot;, и запрос вернёт пустой результат.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE (&lt;br /&gt;
			 nomer_izdelia != &#039;J18&#039;&lt;br /&gt;
			 AND&lt;br /&gt;
			 nomer_postavshika  = S.nomer_postavshika)&lt;br /&gt;
		      OR&lt;br /&gt;
		        (&lt;br /&gt;
		         nomer_izdelia = &#039;J18&#039;&lt;br /&gt;
		         AND&lt;br /&gt;
		         nomer_postavshika != S.nomer_postavshika&lt;br /&gt;
			)&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;!-- этот запрос не подходит под &amp;quot;только и только&amp;quot;, подробности в начале страницы&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj A JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON A.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE nomer_izdelia = &#039;J1&#039;&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_postavshika&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_izdelia != &#039;J1&#039;&lt;br /&gt;
                    AND nomer_postavshika = A.nomer_postavshika&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 ----------------&lt;br /&gt;
  Безликий&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 15 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования изделий, для которых детали поставляют только те поставщики, у которых состояние больше 1000000 у.е.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
		  SELECT *&lt;br /&gt;
		  FROM spasoi_ekz.spj X JOIN spasoi_ekz.s S&lt;br /&gt;
		                          ON X.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
		  WHERE sostoyanie &amp;lt;= 1000000&lt;br /&gt;
		  AND X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Вариант этого запроса без NOT EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000000&lt;br /&gt;
  AND SPJ.nomer_izdelia NOT IN (&lt;br /&gt;
                                SELECT nomer_izdelia&lt;br /&gt;
                                FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                WHERE sostoyanie &amp;lt; 1000000&lt;br /&gt;
                               );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
  уникальное изделие&lt;br /&gt;
  процессор&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 16 ===&lt;br /&gt;
Написать запрос SELECT: выдать цвета и для каждого цвета общее количество деталей, входящих в изделие с названием &#039;Панно 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT cvet AS &amp;quot;Цвет&amp;quot;, SUM(kolichestvo) AS &amp;quot;Деталей&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			     AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
			JOIN spasoi_ekz.P P&lt;br /&gt;
			  ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
GROUP BY cvet;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Другой вариант запроса для тонко чувствующих натур&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT cvet AS &amp;quot;Цвет&amp;quot;, SUM(kolichestvo) AS &amp;quot;Деталей&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
			JOIN spasoi_ekz.j J&lt;br /&gt;
			  ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
GROUP BY cvet;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Цвет  | Деталей&lt;br /&gt;
 -------+---------&lt;br /&gt;
  белый |       9&lt;br /&gt;
  серый |       5&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 17 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков и количество сделанных ими поставок при условии, что среднее число деталей во всех этих поставках больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_postavshika AS &amp;quot;Номер поставщика&amp;quot;,&lt;br /&gt;
       COUNT(*) AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_postavshika HAVING AVG(kolichestvo) &amp;gt; 1000;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_postavshika AS &amp;quot;Номер поставщика&amp;quot;, COUNT(*) AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE nomer_postavshika IN (&lt;br /&gt;
                            SELECT nomer_postavshika&lt;br /&gt;
                            FROM spasoi_ekz.spj&lt;br /&gt;
                            GROUP BY nomer_postavshika HAVING AVG(kolichestvo) &amp;gt; 1000&lt;br /&gt;
                           )&lt;br /&gt;
GROUP BY nomer_postavshika;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_postavshika AS &amp;quot;Номер поставщика&amp;quot;, COUNT(*) AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE (&lt;br /&gt;
       SELECT AVG(kolichestvo)&lt;br /&gt;
       FROM spasoi_ekz.spj X&lt;br /&gt;
       WHERE X.nomer_postavshika = spj.nomer_postavshika&lt;br /&gt;
       ) &amp;gt; 1000&lt;br /&gt;
GROUP BY nomer_postavshika;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И даже ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nom AS &amp;quot;Номер поставщика&amp;quot;, cnt AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT S.nomer_postavshika AS nom,&lt;br /&gt;
             COUNT(SPJ.nomer_postavshika) AS cnt,&lt;br /&gt;
             AVG(SPJ.kolichestvo) AS kol&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
      GROUP BY S.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kol &amp;gt; 1000;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер поставщика | Количество поставок&lt;br /&gt;
 ------------------+---------------------&lt;br /&gt;
  S13              |                   1&lt;br /&gt;
  S6               |                   7&lt;br /&gt;
  S14              |                   1&lt;br /&gt;
  S15              |                   1&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 18 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, имеющих состояние больше 1000 и поставляющих деталь с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем средний объём поставки, выполненной поставщиками с именем &#039;Иванов&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:2nd dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Второй по сложности запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;4px&amp;quot;&amp;gt;&#039;&#039;&#039;Вот уж не свезло, так не свезло&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                       ON SPJ.nomer_postavshika = S.nomer_postavshika &lt;br /&gt;
                     WHERE S.imya = &#039;Иванов&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 19 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия красных деталей, которые входят только в изделие с названием &#039;Рама 02-03&#039; в количестве, меньшем 10 единиц в поставке.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT X.nazvanie&lt;br /&gt;
FROM spasoi_ekz.p X JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_detali = X.nomer_detali&lt;br /&gt;
WHERE X.cvet = &#039;красный&#039;&lt;br /&gt;
  AND kolichestvo &amp;lt; 10&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                                        ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                    AND X.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                              AND J.nazvanie = LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;lt; 10&lt;br /&gt;
  AND SPJ.nomer_detali NOT IN (&lt;br /&gt;
                               SELECT nomer_detali&lt;br /&gt;
                               FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                         ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                            AND J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 ----------------&lt;br /&gt;
  усиленная рама&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 20 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих только белые детали.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                            ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                  WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    AND P.cvet != &#039;белый&#039;&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;белый&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE S.nomer_postavshika NOT IN (&lt;br /&gt;
                                  SELECT nomer_postavshika&lt;br /&gt;
                                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                                            ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                               AND cvet != &#039;белый&#039;&lt;br /&gt;
                                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika NOT IN  (&lt;br /&gt;
                                 SELECT spj.nomer_postavshika&lt;br /&gt;
                                 FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                                 WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                   AND p.cvet != &#039;белый&#039;&lt;br /&gt;
                                )&lt;br /&gt;
  AND nomer_postavshika  IN (&lt;br /&gt;
                             SELECT spj.nomer_postavshika&lt;br /&gt;
                             FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                             WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                               AND p.cvet = &#039;белый&#039;&lt;br /&gt;
                            );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 -----------------&lt;br /&gt;
  Рендилл Тарли&lt;br /&gt;
  Сэмвелл Тарли&lt;br /&gt;
  Мелисса Флорент&lt;br /&gt;
  Томми Версетти&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 21 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, для которых детали поставляет только и только поставщик с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Чтобы продемонстрировать выполнение запроса наглядно, возьмём поставщика не &#039;S1&#039;, а &#039;S18&#039;, который был создан специально для этого запроса. Если оставить &#039;S1&#039;, то наглядности не получится, так как по нашей схеме БД этот поставщик не попадает под условие &amp;quot;&#039;&#039;только и только&#039;&#039;&amp;quot;, и запрос вернёт пустой результат.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S18&#039;&lt;br /&gt;
                    AND nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                 )&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S18&#039;&lt;br /&gt;
                    AND nomer_izdelia != J.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кинжал&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 22 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют только детали с номером &#039;P1&#039; для изделия с именем &#039;Штуцер 01-02&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj X JOIN spasoi_ekz.j J&lt;br /&gt;
                                          ON X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE X.nomer_detali != &#039;P1&#039; &lt;br /&gt;
                    AND j.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                    AND S.nomer_postavshika = X.nomer_postavshika&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- неверный запрос - номер изделия, а не название&lt;br /&gt;
SELECT imya FROM S X&lt;br /&gt;
JOIN SPJ Y ON X.nomer_postavshika=Y.nomer_postavshika&lt;br /&gt;
WHERE X.nomer_postavshika NOT IN (&lt;br /&gt;
                  SELECT DISTINCT nomer_postavshika FROM SPJ Z&lt;br /&gt;
                  WHERE Z.nomer_izdelia != &#039;Штуцер 01-02&#039;&lt;br /&gt;
                  AND Z.nomer_detali!=&#039;P1&#039;);--&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND SPJ.nomer_detali = &#039;P1&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE SPJ.nomer_postavshika NOT IN (&lt;br /&gt;
                                    SELECT nomer_postavshika&lt;br /&gt;
                                    FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                              ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                                 AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                                                            JOIN spasoi_ekz.p P&lt;br /&gt;
                                                              ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                                 AND SPJ.nomer_detali != &#039;P1&#039;&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Иван&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 23 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют деталь с названием &#039;Винт&#039; в количестве большим 100 единиц в одной поставке и имеют состояние больше среднего по их родному городу.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Винт&#039;)&lt;br /&gt;
  AND SPJ.kolichestvo &amp;gt; 100&lt;br /&gt;
  AND S.sostoyanie &amp;gt; (&lt;br /&gt;
                      SELECT AVG(SS.sostoyanie)&lt;br /&gt;
                      FROM spasoi_ekz.s SS&lt;br /&gt;
                      WHERE SS.gorod = S.gorod&lt;br /&gt;
                     );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 24 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в одном городе.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- С этим запросом возникла неожиданная проблема - задание то ли неполное, то ли неправильное, потому что нельзя однозначно сказать, что по нему требуется сделать.&lt;br /&gt;
&lt;br /&gt;
Так что тут несколько вариантов запросов (кто как понял).&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Первый вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, kol&lt;br /&gt;
FROM spasoi_ekz.p A, (&lt;br /&gt;
                      SELECT X.gorod, SUM(kolichestvo) as kol&lt;br /&gt;
                      FROM spasoi_ekz.p X, spasoi_ekz.spj Y&lt;br /&gt;
                      WHERE Y.nomer_detali = X.nomer_detali&lt;br /&gt;
                      GROUP BY X.gorod&lt;br /&gt;
                     ) B&lt;br /&gt;
WHERE A.gorod = B.gorod;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
        nazvanie       | kol&lt;br /&gt;
 ----------------------+------&lt;br /&gt;
  подставка            |    9&lt;br /&gt;
  стойка               |    9&lt;br /&gt;
  абажур               |    9&lt;br /&gt;
  гайка                |  139&lt;br /&gt;
  ось                  |   60&lt;br /&gt;
  зубчатое колесо      |   60&lt;br /&gt;
  транзистор           |   50&lt;br /&gt;
  печатная плата       |   50&lt;br /&gt;
  диод                 |   50&lt;br /&gt;
  универсальная деталь |   13&lt;br /&gt;
  уникальная деталь    |   14&lt;br /&gt;
  болт                 | 9137&lt;br /&gt;
  рама                 |   69&lt;br /&gt;
  колесо               |   69&lt;br /&gt;
  втулка               |   69&lt;br /&gt;
  бумага               | 3122&lt;br /&gt;
  плитка               |   14&lt;br /&gt;
  орнамент             |   14&lt;br /&gt;
  уголок               |   14&lt;br /&gt;
  гайка 01-01          |   27&lt;br /&gt;
  усиленная рама       |   10&lt;br /&gt;
  винт                 | 9137&lt;br /&gt;
  труселя              |    1&lt;br /&gt;
  штуцерная деталь     |   10&lt;br /&gt;
  шуруп                |  139&lt;br /&gt;
 (25 rows)&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
и --&amp;gt;&lt;br /&gt;
В уточнение задания Григорьев сказал следующее: &amp;quot;&#039;&#039;Следует учесть, что в качестве наименования города может выступать переменная, в которую в некоторой программе должно быть занесено конкретное значение перед выполнением запроса&#039;&#039;&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
То есть, вообще говоря, задание на запрос неполное, и его можно трактовать так: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в городе &amp;lt;code&amp;gt;%НАЗВАНИЕГОРОДА%&amp;lt;/code&amp;gt;. Вот эта переменная задаётся где-то в программе, а в БД идёт запрос с уже подставленным конкретным названием. &lt;br /&gt;
&lt;br /&gt;
Этот вариант запроса составлен, например, для Лондона. &lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
WHERE gorod = &#039;Лондон&#039;&lt;br /&gt;
GROUP BY nazvanie;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie | sum&lt;br /&gt;
 ----------+-----&lt;br /&gt;
  гайка    |  71&lt;br /&gt;
  шуруп    |  68&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 25 ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих хотя бы одну белую деталь для изделия с названием &#039;Велосипед 01-04&#039; с объёмом поставки большим, чем средний объём поставки этого поставщика.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ&lt;br /&gt;
                     WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 26 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера красных деталей и количество поставок этих деталей.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY P.nomer_detali;   &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос через JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT SPJ.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY SPJ.nomer_detali;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Количество поставок с ней&lt;br /&gt;
 --------------+---------------------------&lt;br /&gt;
  P15          |                         3&lt;br /&gt;
  P22          |                         1&lt;br /&gt;
  P24          |                         1&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 27 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования городов и среднее состояние поставщиков для каждого города, поставляющих детали с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем минимальный объём поставки, выполненной поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:1st dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;7px&amp;quot;&amp;gt;&#039;&#039;&#039;Сложнейший запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Сохрани Джа, вытащить такое&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.gorod AS &amp;quot;Город&amp;quot;, AVG(S.sostoyanie) AS &amp;quot;Среднее состояние&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT MIN(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                    )&lt;br /&gt;
GROUP BY S.gorod;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    Город   |   Среднее состояние&lt;br /&gt;
 -----------+-----------------------&lt;br /&gt;
  Мытищи    |    35000.500000000000&lt;br /&gt;
  Йокогама  |  1500000.000000000000&lt;br /&gt;
  Манчестер | 2571.0000000000000000&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 28 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входит хотя бы одна красная деталь весом больше 10 граммов, поставляемая только поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ1&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ1.nomer_izdelia&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ1.nomer_detali&lt;br /&gt;
WHERE P.ves &amp;gt; 10&lt;br /&gt;
 AND P.cvet = &#039;красный&#039;&lt;br /&gt;
 AND NOT EXISTS (&lt;br /&gt;
                 SELECT SPJ2.nomer_postavshika&lt;br /&gt;
                 FROM spasoi_ekz.spj SPJ2         &lt;br /&gt;
                 WHERE SPJ2.nomer_detali = P.nomer_detali&lt;br /&gt;
	 	   AND SPJ2.nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                );                     &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 -----------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 29 ===&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, которые входят только и только в состав изделия с названием &#039;Штуцер 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.p&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT SPJ.nomer_izdelia&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                            ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                  WHERE (&lt;br /&gt;
                         J.nazvanie != LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                     OR (&lt;br /&gt;
                         J.nazvanie = LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali != P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 ------------------&lt;br /&gt;
  штуцерная деталь&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 30 ===&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------------&lt;br /&gt;
  Оша&lt;br /&gt;
  Бран Старк&lt;br /&gt;
 (2 rows)&lt;br /&gt;
[[Категория:Структурное проектирование АСОИ (10 семестр)]]&lt;/div&gt;</summary>
		<author><name>195.19.50.70</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%A7%D1%82%D0%BE_%D1%81%D0%B4%D0%B0%D0%B2%D0%B0%D1%82%D1%8C_%D0%B2_10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80%D0%B5&amp;diff=3490</id>
		<title>Что сдавать в 10 семестре</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%A7%D1%82%D0%BE_%D1%81%D0%B4%D0%B0%D0%B2%D0%B0%D1%82%D1%8C_%D0%B2_10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80%D0%B5&amp;diff=3490"/>
		<updated>2013-05-13T14:42:58Z</updated>

		<summary type="html">&lt;p&gt;195.19.50.70: разбил по табличкам&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;В таблице приведён список всего того, что мешает жить в 10 семестре.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! Предмет !! ЛР !! ДЗ !! РК !! Курсовой !! В конце&lt;br /&gt;
  |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Надёжность и достоверность (10 семестр) | Надёжность и достоверность]] || - || 4 || - || по плану в 11 семестре, но можно сдать сейчас || &amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&#039;&#039;&#039;экзамен&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
  |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Технологии программирования (10 семестр) | Технологии программирования]] || 3 || - || - || да || &amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&#039;&#039;&#039;экзамен&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
  |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Технологии разработки ПО (10 семестр) | Технологии разработки ПО]] || 8 || 1 || 2 || - || &amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&#039;&#039;&#039;экзамен&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Структурное проектирование АСОИ (10 семестр) | Структурное проектирование АСОИ]] || 2 || - || - || да || &amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&#039;&#039;&#039;экзамен&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! Предмет !! ЛР !! ДЗ !! РК !! Курсовой !! В конце&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Распределённые системы (10 семестр) | Распределённые системы]] || - || - || 2 || - || &amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&#039;&#039;&#039;зачёт&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
  |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Архитектура корпоративных информационных систем (10 семестр) | Архитектура корпоративных ИС]] || - || 1 || - || - || &amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&#039;&#039;&#039;зачёт&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[Вычислительный практикум (10 семестр) | Вычислительный практикум]] || 8 || - || - || - || &amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&#039;&#039;&#039;зачёт&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | [[:Категория:Аналитические модели СОИ (10 семестр) | Аналитические модели СОИ]] || - || 6 || - || - || &amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&#039;&#039;&#039;зачёт&#039;&#039;&#039;&amp;lt;/font&amp;gt;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Категория:10 семестр]]&lt;/div&gt;</summary>
		<author><name>195.19.50.70</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9E%D0%B1%D1%81%D1%83%D0%B6%D0%B4%D0%B5%D0%BD%D0%B8%D0%B5_%D1%83%D1%87%D0%B0%D1%81%D1%82%D0%BD%D0%B8%D0%BA%D0%B0:ILobster&amp;diff=2618</id>
		<title>Обсуждение участника:ILobster</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9E%D0%B1%D1%81%D1%83%D0%B6%D0%B4%D0%B5%D0%BD%D0%B8%D0%B5_%D1%83%D1%87%D0%B0%D1%81%D1%82%D0%BD%D0%B8%D0%BA%D0%B0:ILobster&amp;diff=2618"/>
		<updated>2013-01-20T14:45:19Z</updated>

		<summary type="html">&lt;p&gt;195.19.50.70: Новая страница: «В К2 ошибка, не L -&amp;gt; PRS, а B -&amp;gt; PRS»&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;В К2 ошибка, не L -&amp;gt; PRS, а B -&amp;gt; PRS&lt;/div&gt;</summary>
		<author><name>195.19.50.70</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%A2%D0%9E%D0%A0%D0%90_(9)_-_%D0%A1%D0%B5%D0%BC%D0%B8%D0%BD%D0%B0%D1%80_%E2%84%967_-_%D0%A1%D0%B8%D0%BD%D1%82%D0%B5%D0%B7_%D1%85%D0%BE%D1%80%D0%BE%D1%88%D0%B5%D0%B9_%D0%91%D0%94&amp;diff=2616</id>
		<title>ТОРА (9) - Семинар №7 - Синтез хорошей БД</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%A2%D0%9E%D0%A0%D0%90_(9)_-_%D0%A1%D0%B5%D0%BC%D0%B8%D0%BD%D0%B0%D1%80_%E2%84%967_-_%D0%A1%D0%B8%D0%BD%D1%82%D0%B5%D0%B7_%D1%85%D0%BE%D1%80%D0%BE%D1%88%D0%B5%D0%B9_%D0%91%D0%94&amp;diff=2616"/>
		<updated>2013-01-20T14:35:14Z</updated>

		<summary type="html">&lt;p&gt;195.19.50.70: ошибка в К4&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{{Backward|l=ТОРА (9) - Семинар №6 - Синтез хорошей БД}}&lt;br /&gt;
__TOC__&lt;br /&gt;
== Продолжение решения ДЗ №2 ==&lt;br /&gt;
&lt;br /&gt;
Продолжаем решать [[ТОРА (9) - Семинар №5 - Синтез хорошей БД#Вторая задача | вторую задачу второго ДЗ]]. Начало решения - в предыдущем семинаре.&lt;br /&gt;
&lt;br /&gt;
4) разбиваем на классы эквивалентности:&lt;br /&gt;
&lt;br /&gt;
{|&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=A\rightarrow CNO}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_1 = ACNO}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=B\rightarrow PRS}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_2 = BPRS}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=AD\rightarrow CNOXVTBPRSE}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_3 = ACDNOXVTPRSE}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=K\rightarrow DELTVXBPRS}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_4\rightarrow KDELTVXBPRS}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=L\rightarrow T}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_5 = LT}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=X\rightarrow VT}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_6 = XVT}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=ET\rightarrow V}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_7 = EVT}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=D\rightarrow XEBPRSVT}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_8 = DXEBPRSVT}}&lt;br /&gt;
 |-&lt;br /&gt;
 | style=&amp;quot;text-align:right;&amp;quot; | {{Формула|f=ABCDEKLNOPRSTVX\rightarrow\varnothing}} || &amp;amp;nbsp;&amp;amp;nbsp;-&amp;amp;nbsp;&amp;amp;nbsp; || {{Формула|f=K_9 = ABCDEKLNOPRSTVX}}&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
5) граф классов эквивалентности:&lt;br /&gt;
&lt;br /&gt;
[[Файл:9sTORAs7pic1.png|500px|center]]&lt;br /&gt;
&lt;br /&gt;
6) редуцируем:&lt;br /&gt;
&lt;br /&gt;
[[Файл:9sTORAs7pic2.png|500px|center]]&lt;br /&gt;
&lt;br /&gt;
7)&lt;br /&gt;
&lt;br /&gt;
:смотри граф.&lt;br /&gt;
&lt;br /&gt;
8)&lt;br /&gt;
&lt;br /&gt;
:{{Формула|f=AD\rightarrow\varnothing}}&lt;br /&gt;
&lt;br /&gt;
9)&lt;br /&gt;
&lt;br /&gt;
:{{Формула|f=\rho = (ACNO, XVT, BPRS, ETV, LT, DXBE, KDL, AK) = (R_1, R_2, R_3, R_4, R_5, R_6, R_7, R_8}}&lt;br /&gt;
&lt;br /&gt;
10)&lt;br /&gt;
&lt;br /&gt;
:* проверяем свойство сохранения без потерь:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot; style=&amp;quot;margin:auto;&amp;quot;&lt;br /&gt;
 ! !! {{Формула|f=A}} !! {{Формула|f=B}} !! {{Формула|f=C}} !! {{Формула|f=D}} !! {{Формула|f=E}} !! {{Формула|f=K}} !! {{Формула|f=L}} !! {{Формула|f=N}} !! {{Формула|f=O}} !! {{Формула|f=P}} !! {{Формула|f=R}} !! {{Формула|f=S}} !! {{Формула|f=T}} !! {{Формула|f=V}} !! {{Формула|f=X}}&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=ACNO}}&lt;br /&gt;
 | {{Формула|f=a}} || || {{Формула|f=a}} || || || || || {{Формула|f=a}} || {{Формула|f=a}} || || || || || ||&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=XVT}}&lt;br /&gt;
 | || || || || || || || || || || || || {{Формула|f=a}} || {{Формула|f=a}} || {{Формула|f=a}}&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=BPRS}}&lt;br /&gt;
 | || {{Формула|f=a}} || || || || || || || || {{Формула|f=a}} || {{Формула|f=a}} || {{Формула|f=a}} || || ||&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=ETV}}&lt;br /&gt;
 | || || || || {{Формула|f=a}} || || || || || || || || {{Формула|f=a}} || {{Формула|f=a}} ||&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=LT}}&lt;br /&gt;
 | || || || || || || {{Формула|f=a}} || || || || || || {{Формула|f=a}} || ||&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=DXBE}}&lt;br /&gt;
 | || {{Формула|f=a}} || || {{Формула|f=a}} || {{Формула|f=a}} || || || || || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || {{Формула|f=a}}&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=KDL}}&lt;br /&gt;
 | || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || || {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || {{Формула|f=a}} || {{Формула|f=a}} || || || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}}&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 ! {{Формула|f=AK}}&lt;br /&gt;
 | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}} || bgcolor=&amp;quot;lime&amp;quot; | {{Формула|f=a}}&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
:получили строку, сплошь состоящую из {{Формула|f=a}}. Значит, схема &amp;lt;u&amp;gt;обладает свойством соединения без потерь&amp;lt;/u&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
:* проверяем свойство сохранения функциональных зависимостей:&lt;br /&gt;
::{{Формула|f=УНП = (A\rightarrow CNO, B\rightarrow PRS, AD\rightarrow XCNOVTBPRSE, K\rightarrow DELTVXBPRS,}}&lt;br /&gt;
::{{Формула|f=L\rightarrow T, X\rightarrow VT, ET\rightarrow V, D\rightarrow XBEVTPRS)}}&lt;br /&gt;
::1-4)&lt;br /&gt;
:::{{Формула|f=H\neq\varnothing}}&lt;br /&gt;
::5)&lt;br /&gt;
:::{{Формула|f=УНП - H = (A\rightarrow CNO, B\rightarrow PRS, K\rightarrow DL, L\rightarrow T, X\rightarrow VT, ET\rightarrow V, D\rightarrow XBE)}} &lt;br /&gt;
:::{{Формула|f=H = (AD\rightarrow CNOVTPRSXBE, K\rightarrow EXBTVPRS, D\rightarrow PPRSVT)}}&lt;br /&gt;
::6)&lt;br /&gt;
:::{{Формула|f=AD\rightarrow^? CNOVTPRSXBE}} &amp;lt;span style=&amp;quot;color:green&amp;quot;&amp;gt;да&amp;lt;/span&amp;gt;&lt;br /&gt;
:::{{Формула|f=(AD)^+ = ADCNOXBEPRSVT}}&lt;br /&gt;
&lt;br /&gt;
:::{{Формула|f=K\rightarrow^? XBTEVPRS}} &amp;lt;span style=&amp;quot;color:green&amp;quot;&amp;gt;да&amp;lt;/span&amp;gt;&lt;br /&gt;
:::{{Формула|f=(AD)^+ = KDLXBEVTPRS}}&lt;br /&gt;
&lt;br /&gt;
:::{{Формула|f=D\rightarrow^? PRSVT}} &amp;lt;span style=&amp;quot;color:green&amp;quot;&amp;gt;да&amp;lt;/span&amp;gt;&lt;br /&gt;
:::{{Формула|f=(AD)^+ = DXBEPRSVT}}&lt;br /&gt;
&lt;br /&gt;
:значит, схема &amp;lt;u&amp;gt;обладает свойством сохранения функциональных зависимостей&amp;lt;/u&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
А теперь строим схему в нотации ERwin:&lt;br /&gt;
&lt;br /&gt;
[[Файл:9sTORAs7pic3.png|500px|center]]&lt;br /&gt;
&lt;br /&gt;
переделываем в схему с синтетическими ключами:&lt;br /&gt;
&lt;br /&gt;
[[Файл:9sTORAs7pic4.png|500px|center]]&lt;br /&gt;
&lt;br /&gt;
== ДЗ №3 ==&lt;br /&gt;
&lt;br /&gt;
Пусть на сервер базы данных поступает оператор &amp;lt;code&amp;gt;SELECT&amp;lt;/code&amp;gt;, соответствующий следующему запросу: &amp;quot;&#039;&#039;Выдать имена поставщиков из Лондона, которые поставляют для изделия с номером {{Формула|f=J1}}, по крайней мере, одну красную деталь&#039;&#039;&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
Схема базы данных (таблицы {{Формула|f=S}}, {{Формула|f=P}}, {{Формула|f=J}}, {{Формула|f=SPJ}}) в виде ER-диаграммы:&lt;br /&gt;
&lt;br /&gt;
[[Файл:9sTORAs7pic5.png|center|500px]]&lt;br /&gt;
&lt;br /&gt;
Схема базы данных: {{Формула|f=\rho = (S, P, J, SPJ)}}.&lt;br /&gt;
&lt;br /&gt;
здесь:&lt;br /&gt;
:{{Формула|f=S}} - таблица &amp;quot;Поставщик&amp;quot;, описывающая поставщиков деталей. Имеет следующие поля:&lt;br /&gt;
:* &amp;lt;u&amp;gt;номер поставщика&amp;lt;/u&amp;gt; - идентификационный номер поставщика (ключевое поле);&lt;br /&gt;
:* имя - фамилия, имя и отчество поставщика;&lt;br /&gt;
:* состояние - состояние поставщика (состояние счета);&lt;br /&gt;
:* город - город, в котором проживает поставщик и в котором находится его центральный офис.&lt;br /&gt;
&lt;br /&gt;
:{{Формула|f=P}} - таблица &amp;quot;Деталь&amp;quot;. Описывает поставляемые детали и включает следующие поля:&lt;br /&gt;
:* &amp;lt;u&amp;gt;номер детали&amp;lt;/u&amp;gt; - идентификационный номер детали (ключевое поле);&lt;br /&gt;
:* название - название детали;&lt;br /&gt;
:* цвет - цвет детали;&lt;br /&gt;
:* вес - все детали в фунтах;&lt;br /&gt;
:* город - город, в котором изготавливается деталь.&lt;br /&gt;
&lt;br /&gt;
:{{Формула|f=J}} - таблица &amp;quot;Изделие&amp;quot;. Описывает изготавливаемые изделия и включает следующие поля&lt;br /&gt;
:* &amp;lt;u&amp;gt;номер изделия&amp;lt;/u&amp;gt; - идентификационный номер изделия (ключевое поле);&lt;br /&gt;
:* название - название изделия;&lt;br /&gt;
:* город - город, где изготавливается изделие.&lt;br /&gt;
&lt;br /&gt;
:{{Формула|f=SPJ}} - таблица &amp;quot;Сборка&amp;quot;. Имеет следующие поля:&lt;br /&gt;
:* &amp;lt;u&amp;gt;номер поставщика&amp;lt;/u&amp;gt; — идентификационный номер поставщика, поставляющего деталь (ключевое поле);&lt;br /&gt;
:* &amp;lt;u&amp;gt;номер детали&amp;lt;/u&amp;gt; - идентификационный номер детали, поставляемой поставщиком (ключевое поле);&lt;br /&gt;
:* &amp;lt;u&amp;gt;номер изделия&amp;lt;/u&amp;gt; - идентификационный номер изделия, в которое входит деталь, поставляемая поставщиком (ключевое поле);&lt;br /&gt;
:* количество - количество деталей, поставляемых поставщиком для данного изделия (количество деталей в поставке).&lt;br /&gt;
&lt;br /&gt;
&amp;lt;u&amp;gt;Задание&amp;lt;/u&amp;gt;:&lt;br /&gt;
# Написать соответствующий оператор &amp;lt;code&amp;gt;SELECT&amp;lt;/code&amp;gt; и построить логический план выполнения этого оператора.&lt;br /&gt;
# Определить оптимальный физический план выполнения оператора &amp;lt;code&amp;gt;SELECT&amp;lt;/code&amp;gt; при следующих исходных данных:&lt;br /&gt;
&lt;br /&gt;
::1) Количество записей в таблицах:&lt;br /&gt;
:::{{Формула|f=T(S)=10000}}, {{Формула|f=T(P)=100000}}, {{Формула|f=T(SPJ)=1000000}}.&lt;br /&gt;
&lt;br /&gt;
::2) Количество записей в одном блоке таблицы:&lt;br /&gt;
:::{{Формула|f=L_s=500}}, {{Формула|f=L_p=500}}, {{Формула|f=L_{SPJ}=1000}}, {{Формула|f=L_{JOIN}=2000}}.&lt;br /&gt;
&lt;br /&gt;
::3) Индексы по атрибутам и число записей таблицы в одном блоке индекса ({{Формула|f=L}}):&lt;br /&gt;
::таблица {{Формула|f=S}}:&lt;br /&gt;
:::* индекс по атрибуту &amp;quot;номер поставщика&amp;quot;, {{Формула|f=L=200}};&lt;br /&gt;
::таблица {{Формула|f=Р}}:&lt;br /&gt;
:::* индекс по атрибуту &amp;quot;номер детали&amp;quot;, {{Формула|f=L=200}};&lt;br /&gt;
:: таблица {{Формула|f=SPJ}}:&lt;br /&gt;
:::* индекс по атрибуту &amp;quot;номер поставщика&amp;quot;, {{Формула|f=L=200}};&lt;br /&gt;
:::* индекс по атрибуту &amp;quot;номер детали&amp;quot;, {{Формула|f=L=200}};&lt;br /&gt;
:::* индекс по атрибуту &amp;quot;номер изделия&amp;quot;, {{Формула|f=L=200}}.&lt;br /&gt;
::&amp;lt;span style=&amp;quot;color:blue&amp;quot;&amp;gt;&#039;&#039;Примечания:&#039;&#039;&lt;br /&gt;
:::* &#039;&#039;записи таблиц могут читаться в отсортированном виде по своим индексированным атрибутам&#039;&#039;;&lt;br /&gt;
:::* &#039;&#039;записи во всех таблицах не сгруппированы (нет кластеризации).&#039;&#039;&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
::4) Мощности атрибутов:&lt;br /&gt;
::* {{Формула|f=I(S, город) = 50}}, {{Формула|f=I(S, номер\_ поставщика) = 10000}};&lt;br /&gt;
::* {{Формула|f=I(Р, цвет) = 20}}, {{Формула|f=I(Р, номер\_ детали) = 100000}};&lt;br /&gt;
::* {{Формула|f=I(SPJ, номер\_ поставщика) = 5000}}, {{Формула|f=I(SPJ, номер\_ детали) = 100000}}, {{Формула|f=I(SPJ, номер\_ изделия) = 10000}}.&lt;br /&gt;
&lt;br /&gt;
::5) Число блоков {{Формула|f=b=10}}, значения {{Формула|f=C_{comp} = C_{move} = C_{filter} = 0.01}} мс, {{Формула|f=C_B = 10}} мс.&lt;br /&gt;
&lt;br /&gt;
::6) Предполагается, что используются левосторонние деревья для поиска оптимального плана и применяются каналы.&lt;br /&gt;
::&amp;lt;span style=&amp;quot;color:blue&amp;quot;&amp;gt;&#039;&#039;Примечание: метод хешированного соединения не рассматривать.&#039;&#039;&amp;lt;/span&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Пример решения можно посмотреть в [[ТОРА (9) - Семинар №8 - Пример решения ДЗ на оптимизацию запроса | последнем семинаре]].&lt;br /&gt;
&lt;br /&gt;
[[Категория:Теоретические основы реляционной алгебры (9 семестр)|С]]&lt;br /&gt;
[[Категория:Конспекты лекций и семинаров]]&lt;/div&gt;</summary>
		<author><name>195.19.50.70</name></author>
	</entry>
</feed>