<?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.91.240.97</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.91.240.97"/>
	<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.91.240.97"/>
	<updated>2026-04-30T14:15:14Z</updated>
	<subtitle>Вклад</subtitle>
	<generator>MediaWiki 1.41.0</generator>
	<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:%D0%97%D0%B0%D0%B3%D0%BB%D0%B0%D0%B2%D0%BD%D0%B0%D1%8F_%D1%81%D1%82%D1%80%D0%B0%D0%BD%D0%B8%D1%86%D0%B0&amp;diff=5575</id>
		<title>Обсуждение:Заглавная страница</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:%D0%97%D0%B0%D0%B3%D0%BB%D0%B0%D0%B2%D0%BD%D0%B0%D1%8F_%D1%81%D1%82%D1%80%D0%B0%D0%BD%D0%B8%D1%86%D0%B0&amp;diff=5575"/>
		<updated>2017-09-11T22:25:08Z</updated>

		<summary type="html">&lt;p&gt;195.91.240.97: /* мб стоит отделить бакалавров от магистров? */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Для обсуждения всего, что касается портала. Пишите любые вопросы, предложения, угрозы.&lt;br /&gt;
&lt;br /&gt;
== приветик от тайного друга ==&lt;br /&gt;
&lt;br /&gt;
спасибо. очень хороший &lt;br /&gt;
и полезный сайт. &lt;br /&gt;
удачииуспехавам.&lt;br /&gt;
: Всё для вас :) [[Участник:ILobster|iLobster]] ([[Обсуждение участника:ILobster|обсуждение]]) 17:40, 18 апреля 2016 (MSK)&lt;br /&gt;
&lt;br /&gt;
== мб стоит отделить бакалавров от магистров? ==&lt;br /&gt;
&lt;br /&gt;
мб, только в чём это будет выражаться? Когда мы создавали ресурс, у нас были только специалисты, и с учебным планом было проще. [[Участник:ILobster|iLobster]] ([[Обсуждение участника:ILobster|обсуждение]]) 23:26, 7 сентября 2017 (MSK)&lt;br /&gt;
&lt;br /&gt;
Не вижу никакого смысла. Вполне достаточно делить предметы по семестрам, пользуясь подходом &amp;quot;9 семестр = 1 семестр магистратуры&amp;quot; [[Служебная:Вклад/195.91.240.97|195.91.240.97]] 01:25, 12 сентября 2017 (MSK)&lt;/div&gt;</summary>
		<author><name>195.91.240.97</name></author>
	</entry>
	<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=5374</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=5374"/>
		<updated>2016-06-04T15:37:24Z</updated>

		<summary type="html">&lt;p&gt;195.91.240.97: /* Билет 6 */&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;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
WITH&lt;br /&gt;
  s_all AS (&lt;br /&gt;
      SELECT DISTINCT nomer_detali&lt;br /&gt;
      FROM spasoi_ekz.spj SPJY&lt;br /&gt;
      WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
  )&lt;br /&gt;
&lt;br /&gt;
SELECT&lt;br /&gt;
  spj.nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
  INNER JOIN s_all ON s_all.nomer_detali = spj.nomer_detali&lt;br /&gt;
WHERE&lt;br /&gt;
  nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
GROUP BY nomer_postavshika&lt;br /&gt;
HAVING count(spj.nomer_detali) = (SELECT count(*) FROM s_all);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;!-- &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 spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = &#039;S2&#039;)&lt;br /&gt;
    EXCEPT&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = SPJ.nomer_postavshika)&lt;br /&gt;
)&lt;br /&gt;
AND nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt; --&amp;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;
Еще один вариант:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT&lt;br /&gt;
  p.nazvanie&lt;br /&gt;
FROM spj&lt;br /&gt;
  INNER JOIN j ON spj.nomer_izdelia = j.nomer_izdelia AND j.nazvanie ILIKE &#039;Велосипед 01/23&#039;&lt;br /&gt;
  INNER JOIN s ON (&lt;br /&gt;
    spj.nomer_postavshika = s.nomer_postavshika&lt;br /&gt;
    AND s.gorod = j.gorod&lt;br /&gt;
  )&lt;br /&gt;
  INNER JOIN p ON spj.nomer_detali = p.nomer_detali;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;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;Этот же запрос без 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;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
Этот же запрос без JOIN (точнее, с CROSS JOIN):&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 S.imya&lt;br /&gt;
FROM spasoi_ekz.s S,&lt;br /&gt;
     spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.j J,&lt;br /&gt;
     spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
  AND SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;) &lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
  AND SPJ.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;
&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;
     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&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;
&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;
&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;
-- в котором хоть один поставщик имеет миним. объем &amp;lt;=1000,&lt;br /&gt;
-- а надо, чтобы был отброшен только этот поставщик.&lt;br /&gt;
-- читайте описание конструкции GROUP BY ... HAVING ...&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;
&lt;br /&gt;
-- та же фигня&lt;br /&gt;
SELECT S.gorod, SUM(S.sostoyanie)--, MIN(SPJ.kolichestvo)&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 gorod HAVING MIN(kolichestvo) &amp;gt; 1000;&lt;br /&gt;
&lt;br /&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;&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;
    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;
&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 JOIN spasoi_ekz.spj X&lt;br /&gt;
                          ON J.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
		  SELECT *&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;
		  WHERE sostoyanie &amp;lt;= 1000000&lt;br /&gt;
		  AND 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;
-- Неверный запрос, если в таблице SPJ НЕТ поставок с этим изделием, &lt;br /&gt;
-- а в таблице J - есть это изделие, то запрос вернет его название, хотя не должен&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;
&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;Вариант этого запроса без 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;
&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 P.cvet, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.spj SPJ,&lt;br /&gt;
     spasoi_ekz.j J&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
GROUP BY P.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;
 -------+---------&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; -- или WHERE S.imya LIKE &#039;%Иванов%&#039;,&lt;br /&gt;
                     -- поскольку сказано, что поставка выполнена поставщиками с именем Иванов,&lt;br /&gt;
                     -- а это могут быть разные имена и отчества. Короче, опять великий&lt;br /&gt;
                     -- русский язык в задании - что ещё за &amp;quot;с именем Иванов&amp;quot;&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,&lt;br /&gt;
     spasoi_ekz.spj SPJ,&lt;br /&gt;
     spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
  AND SPJ.nomer_izdelia=J.nomer_izdelia&lt;br /&gt;
  AND S.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 SPJ2, spasoi_ekz.S S2&lt;br /&gt;
		     WHERE S2.nomer_postavshika = SPJ2.nomer_postavshika&lt;br /&gt;
		       AND S2.imya LIKE &#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;
 (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;
Примечание: Григорьев ругается на X.nomer_detali = SPJ.nomer_detali Лучше во вложенном подзапросе сделать еще один джойн p и приравнивать названия деталей. &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;
&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;
&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.spj SPJ2&lt;br /&gt;
WHERE SPJ2.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
                  WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                    AND SPJ.nomer_postavshika = SPJ2.nomer_postavshika&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;
Примечание: Григорьев ругается на nomer_izdelia = J.nomer_izdelia Лучше во вложенном подзапросе сделать еще один джойн j и приравнивать названия изделий, а не номера.&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 X.nomer_postavshika = S.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;
Примечание: Григорьев ругается на SPJ.nomer_detali = P.nomer_detali Лучше во вложенном подзапросе сделать еще один джойн p и приравнивать названия деталей. &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;
&amp;lt;!-- &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 imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = &#039;S2&#039;)&lt;br /&gt;
    EXCEPT&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = SPJ.nomer_postavshika)&lt;br /&gt;
)&lt;br /&gt;
AND nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt; --&amp;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.91.240.97</name></author>
	</entry>
	<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=5372</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=5372"/>
		<updated>2016-06-04T15:30:58Z</updated>

		<summary type="html">&lt;p&gt;195.91.240.97: /* Билет 5 */&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;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
WITH&lt;br /&gt;
  s_all AS (&lt;br /&gt;
      SELECT DISTINCT nomer_detali&lt;br /&gt;
      FROM spasoi_ekz.spj SPJY&lt;br /&gt;
      WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
  )&lt;br /&gt;
&lt;br /&gt;
SELECT&lt;br /&gt;
  spj.nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
  INNER JOIN s_all ON s_all.nomer_detali = spj.nomer_detali&lt;br /&gt;
WHERE&lt;br /&gt;
  nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
GROUP BY nomer_postavshika&lt;br /&gt;
HAVING count(spj.nomer_detali) = (SELECT count(*) FROM s_all);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;!-- &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 spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = &#039;S2&#039;)&lt;br /&gt;
    EXCEPT&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = SPJ.nomer_postavshika)&lt;br /&gt;
)&lt;br /&gt;
AND nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt; --&amp;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 ILIKE &#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;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
Этот же запрос без JOIN (точнее, с CROSS JOIN):&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 S.imya&lt;br /&gt;
FROM spasoi_ekz.s S,&lt;br /&gt;
     spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.j J,&lt;br /&gt;
     spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
  AND SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;) &lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
  AND SPJ.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;
&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;
     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&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;
&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;
&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;
-- в котором хоть один поставщик имеет миним. объем &amp;lt;=1000,&lt;br /&gt;
-- а надо, чтобы был отброшен только этот поставщик.&lt;br /&gt;
-- читайте описание конструкции GROUP BY ... HAVING ...&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;
&lt;br /&gt;
-- та же фигня&lt;br /&gt;
SELECT S.gorod, SUM(S.sostoyanie)--, MIN(SPJ.kolichestvo)&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 gorod HAVING MIN(kolichestvo) &amp;gt; 1000;&lt;br /&gt;
&lt;br /&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;&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;
    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;
&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 JOIN spasoi_ekz.spj X&lt;br /&gt;
                          ON J.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
		  SELECT *&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;
		  WHERE sostoyanie &amp;lt;= 1000000&lt;br /&gt;
		  AND 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;
-- Неверный запрос, если в таблице SPJ НЕТ поставок с этим изделием, &lt;br /&gt;
-- а в таблице J - есть это изделие, то запрос вернет его название, хотя не должен&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;
&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;Вариант этого запроса без 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;
&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 P.cvet, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.spj SPJ,&lt;br /&gt;
     spasoi_ekz.j J&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
GROUP BY P.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;
 -------+---------&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; -- или WHERE S.imya LIKE &#039;%Иванов%&#039;,&lt;br /&gt;
                     -- поскольку сказано, что поставка выполнена поставщиками с именем Иванов,&lt;br /&gt;
                     -- а это могут быть разные имена и отчества. Короче, опять великий&lt;br /&gt;
                     -- русский язык в задании - что ещё за &amp;quot;с именем Иванов&amp;quot;&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,&lt;br /&gt;
     spasoi_ekz.spj SPJ,&lt;br /&gt;
     spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
  AND SPJ.nomer_izdelia=J.nomer_izdelia&lt;br /&gt;
  AND S.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 SPJ2, spasoi_ekz.S S2&lt;br /&gt;
		     WHERE S2.nomer_postavshika = SPJ2.nomer_postavshika&lt;br /&gt;
		       AND S2.imya LIKE &#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;
 (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;
Примечание: Григорьев ругается на X.nomer_detali = SPJ.nomer_detali Лучше во вложенном подзапросе сделать еще один джойн p и приравнивать названия деталей. &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;
&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;
&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.spj SPJ2&lt;br /&gt;
WHERE SPJ2.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
                  WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                    AND SPJ.nomer_postavshika = SPJ2.nomer_postavshika&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;
Примечание: Григорьев ругается на nomer_izdelia = J.nomer_izdelia Лучше во вложенном подзапросе сделать еще один джойн j и приравнивать названия изделий, а не номера.&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 X.nomer_postavshika = S.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;
Примечание: Григорьев ругается на SPJ.nomer_detali = P.nomer_detali Лучше во вложенном подзапросе сделать еще один джойн p и приравнивать названия деталей. &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;
&amp;lt;!-- &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 imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = &#039;S2&#039;)&lt;br /&gt;
    EXCEPT&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = SPJ.nomer_postavshika)&lt;br /&gt;
)&lt;br /&gt;
AND nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt; --&amp;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.91.240.97</name></author>
	</entry>
	<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=5371</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=5371"/>
		<updated>2016-06-04T15:08:47Z</updated>

		<summary type="html">&lt;p&gt;195.91.240.97: /* Билет 1 */&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;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
WITH&lt;br /&gt;
  s_all AS (&lt;br /&gt;
      SELECT DISTINCT nomer_detali&lt;br /&gt;
      FROM spasoi_ekz.spj SPJY&lt;br /&gt;
      WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
  )&lt;br /&gt;
&lt;br /&gt;
SELECT&lt;br /&gt;
  spj.nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
  INNER JOIN s_all ON s_all.nomer_detali = spj.nomer_detali&lt;br /&gt;
WHERE&lt;br /&gt;
  nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
GROUP BY nomer_postavshika&lt;br /&gt;
HAVING count(spj.nomer_detali) = (SELECT count(*) FROM s_all);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;!-- &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 spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = &#039;S2&#039;)&lt;br /&gt;
    EXCEPT&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = SPJ.nomer_postavshika)&lt;br /&gt;
)&lt;br /&gt;
AND nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt; --&amp;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;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
Этот же запрос без JOIN (точнее, с CROSS JOIN):&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 S.imya&lt;br /&gt;
FROM spasoi_ekz.s S,&lt;br /&gt;
     spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.j J,&lt;br /&gt;
     spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
  AND SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;) &lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
  AND SPJ.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;
&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;
     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&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;
&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;
&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;
-- в котором хоть один поставщик имеет миним. объем &amp;lt;=1000,&lt;br /&gt;
-- а надо, чтобы был отброшен только этот поставщик.&lt;br /&gt;
-- читайте описание конструкции GROUP BY ... HAVING ...&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;
&lt;br /&gt;
-- та же фигня&lt;br /&gt;
SELECT S.gorod, SUM(S.sostoyanie)--, MIN(SPJ.kolichestvo)&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 gorod HAVING MIN(kolichestvo) &amp;gt; 1000;&lt;br /&gt;
&lt;br /&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;&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;
    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;
&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 JOIN spasoi_ekz.spj X&lt;br /&gt;
                          ON J.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
		  SELECT *&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;
		  WHERE sostoyanie &amp;lt;= 1000000&lt;br /&gt;
		  AND 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;
-- Неверный запрос, если в таблице SPJ НЕТ поставок с этим изделием, &lt;br /&gt;
-- а в таблице J - есть это изделие, то запрос вернет его название, хотя не должен&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;
&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;Вариант этого запроса без 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;
&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 P.cvet, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.spj SPJ,&lt;br /&gt;
     spasoi_ekz.j J&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
GROUP BY P.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;
 -------+---------&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; -- или WHERE S.imya LIKE &#039;%Иванов%&#039;,&lt;br /&gt;
                     -- поскольку сказано, что поставка выполнена поставщиками с именем Иванов,&lt;br /&gt;
                     -- а это могут быть разные имена и отчества. Короче, опять великий&lt;br /&gt;
                     -- русский язык в задании - что ещё за &amp;quot;с именем Иванов&amp;quot;&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,&lt;br /&gt;
     spasoi_ekz.spj SPJ,&lt;br /&gt;
     spasoi_ekz.p P,&lt;br /&gt;
     spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
  AND SPJ.nomer_izdelia=J.nomer_izdelia&lt;br /&gt;
  AND S.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 SPJ2, spasoi_ekz.S S2&lt;br /&gt;
		     WHERE S2.nomer_postavshika = SPJ2.nomer_postavshika&lt;br /&gt;
		       AND S2.imya LIKE &#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;
 (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;
Примечание: Григорьев ругается на X.nomer_detali = SPJ.nomer_detali Лучше во вложенном подзапросе сделать еще один джойн p и приравнивать названия деталей. &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;
&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;
&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.spj SPJ2&lt;br /&gt;
WHERE SPJ2.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
                  WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                    AND SPJ.nomer_postavshika = SPJ2.nomer_postavshika&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;
Примечание: Григорьев ругается на nomer_izdelia = J.nomer_izdelia Лучше во вложенном подзапросе сделать еще один джойн j и приравнивать названия изделий, а не номера.&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 X.nomer_postavshika = S.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;
Примечание: Григорьев ругается на SPJ.nomer_detali = P.nomer_detali Лучше во вложенном подзапросе сделать еще один джойн p и приравнивать названия деталей. &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;
&amp;lt;!-- &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 imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = &#039;S2&#039;)&lt;br /&gt;
    EXCEPT&lt;br /&gt;
    (SELECT DISTINCT nomer_detali FROM spasoi_ekz.spj WHERE nomer_postavshika = SPJ.nomer_postavshika)&lt;br /&gt;
)&lt;br /&gt;
AND nomer_postavshika != &#039;S2&#039;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt; --&amp;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.91.240.97</name></author>
	</entry>
</feed>