<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>https://iu5bmstu.ru/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=195.19.36.135</id>
	<title>Кафедра ИУ5 МГТУ им. Н.Э.Баумана, студенческое сообщество - Вклад [ru]</title>
	<link rel="self" type="application/atom+xml" href="https://iu5bmstu.ru/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=195.19.36.135"/>
	<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%A1%D0%BB%D1%83%D0%B6%D0%B5%D0%B1%D0%BD%D0%B0%D1%8F:%D0%92%D0%BA%D0%BB%D0%B0%D0%B4/195.19.36.135"/>
	<updated>2026-04-30T05:35:31Z</updated>
	<subtitle>Вклад</subtitle>
	<generator>MediaWiki 1.41.0</generator>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9E%D0%BF%D0%B5%D1%80%D0%B0%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B5_%D1%81%D0%B8%D1%81%D1%82%D0%B5%D0%BC%D1%8B_(5_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=5318</id>
		<title>Операционные системы (5 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9E%D0%BF%D0%B5%D1%80%D0%B0%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B5_%D1%81%D0%B8%D1%81%D1%82%D0%B5%D0%BC%D1%8B_(5_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=5318"/>
		<updated>2015-12-18T09:23:12Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 ! Год !! Описание !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2010 || Лекции || [http://yadi.sk/d/9S3UI6BW8Z4LS загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Категория:5 семестр]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%A2%D0%B5%D0%BE%D1%80%D0%B8%D1%8F_%D0%B2%D0%B5%D1%80%D0%BE%D1%8F%D1%82%D0%BD%D0%BE%D1%81%D1%82%D0%B5%D0%B9_%D0%B8_%D0%BC%D0%B0%D1%82%D0%B5%D0%BC%D0%B0%D1%82%D0%B8%D1%87%D0%B5%D1%81%D0%BA%D0%B0%D1%8F_%D1%81%D1%82%D0%B0%D1%82%D0%B8%D1%81%D1%82%D0%B8%D0%BA%D0%B0_(3_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=4879</id>
		<title>Теория вероятностей и математическая статистика (3 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%A2%D0%B5%D0%BE%D1%80%D0%B8%D1%8F_%D0%B2%D0%B5%D1%80%D0%BE%D1%8F%D1%82%D0%BD%D0%BE%D1%81%D1%82%D0%B5%D0%B9_%D0%B8_%D0%BC%D0%B0%D1%82%D0%B5%D0%BC%D0%B0%D1%82%D0%B8%D1%87%D0%B5%D1%81%D0%BA%D0%B0%D1%8F_%D1%81%D1%82%D0%B0%D1%82%D0%B8%D1%81%D1%82%D0%B8%D0%BA%D0%B0_(3_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=4879"/>
		<updated>2014-10-02T18:24:33Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: учебный план&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 ! Год !! Описание !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2010 || Задачи || [http://yadi.sk/d/iIBbGJlK8Z4q0 загрузить]&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2010 || Лекции || [http://yadi.sk/d/w1irW3Fx8Z4mk загрузить]&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2010 || К экзамену || [http://yadi.sk/d/-4aVBmMx8Z4oW загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
[[Категория:3 семестр]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%AD%D0%BB%D0%B5%D0%BA%D1%82%D1%80%D0%B8%D1%87%D0%B5%D1%81%D0%BA%D0%B8%D0%B9_%D0%BA%D0%BE%D0%BD%D1%81%D0%BF%D0%B5%D0%BA%D1%82&amp;diff=4749</id>
		<title>Электрический конспект</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%AD%D0%BB%D0%B5%D0%BA%D1%82%D1%80%D0%B8%D1%87%D0%B5%D1%81%D0%BA%D0%B8%D0%B9_%D0%BA%D0%BE%D0%BD%D1%81%D0%BF%D0%B5%D0%BA%D1%82&amp;diff=4749"/>
		<updated>2014-06-04T18:06:35Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Где набирать */ добавлены проги под мак&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Это конспект, &amp;lt;!---&amp;lt;strike&amp;gt;который нельзя сжечь&amp;lt;/strike&amp;gt;---&amp;gt; набранный на ноутбуке, планшете (телефоне). От [[Рукописный конспект | рукописного конспекта]] отличается тем, &amp;lt;!---&amp;lt;strike&amp;gt;что его нельзя сжечь&amp;lt;/strike&amp;gt;---&amp;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;
* мгновенно можно создать сколько угодно копий;&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;
* низкий расход краски в принтере при печати;&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;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 ! Операционная система !! ПО !! Что !! Достоинства !! Недостатки&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | rowspan=&amp;quot;4&amp;quot; | &#039;&#039;&#039;Microsoft Windows&#039;&#039;&#039; || Блокнот || текст || очень простой || ничего не умеет&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | Word || текст &amp;lt;br&amp;gt; формулы &amp;lt;br&amp;gt; таблицы &amp;lt;br&amp;gt; простые рисунки || удобный &amp;lt;br&amp;gt; простой || -&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | Visio || схемы &amp;lt;br&amp;gt; рисунки || векторный || -&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | WinEdt + MiKTeX || текст &amp;lt;br&amp;gt; формулы &amp;lt;br&amp;gt; таблицы &amp;lt;br&amp;gt; || может всё &amp;lt;br&amp;gt; аккуратный &amp;lt;br&amp;gt; логичный &amp;lt;br&amp;gt; простой || сложно научиться&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | rowspan=&amp;quot;5&amp;quot; | &#039;&#039;&#039;Linux&#039;&#039;&#039; || Vim/Emacs/Kate/Gedit/SciTe || текст || очень простой || мало что умеет&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | То же самое + LaTeX ИЛИ Kile/TexMaker || текст &amp;lt;br&amp;gt; формулы &amp;lt;br&amp;gt; таблицы &amp;lt;br&amp;gt; || может всё &amp;lt;br&amp;gt; аккуратный &amp;lt;br&amp;gt; логичный &amp;lt;br&amp;gt; простой || сложно научиться&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | LyX || текст &amp;lt;br&amp;gt; формулы &amp;lt;br&amp;gt; таблицы &amp;lt;br&amp;gt; || Тот же LaTeX, но WYSIWYG || -&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | OpenOffice/LibreOffice Writer || текст &amp;lt;br&amp;gt; формулы &amp;lt;br&amp;gt; таблицы &amp;lt;br&amp;gt; простые рисунки || удобный &amp;lt;br&amp;gt; простой || -&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | Dia/Inkscape || схемы &amp;lt;br&amp;gt; рисунки || векторный || Библиотеки Dia хуже, чем в Visio &amp;lt;br&amp;gt; В Inkscape сложно сделать привязку стрелки к элементу&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | rowspan=&amp;quot;3&amp;quot; | &#039;&#039;&#039;Mac OS&#039;&#039;&#039; || MS Office ||  Текст, таблицы || Привычно || дорого или незаконно&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | OmniGraffle || картинки || Поход на Visio || Все же не совсем похож &amp;lt;br&amp;gt; нужно привыкать &amp;lt;br&amp;gt; косяки со вставкой формул&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | macTex + texmaker ||  текст &amp;lt;br&amp;gt; формулы &amp;lt;br&amp;gt; таблицы &amp;lt;br&amp;gt; || см выше || см выше&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | &#039;&#039;&#039;Android&#039;&#039;&#039; || ? || ? || ? || ?&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | &#039;&#039;&#039;?&#039;&#039;&#039; || ? || ? || ? || ?&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;gallery&amp;gt;&lt;br /&gt;
Файл:Elkonsp1.png&lt;br /&gt;
Файл:Elkonsp2.png&lt;br /&gt;
Файл:Elkonsp3.png&lt;br /&gt;
&amp;lt;/gallery&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Категория:Конспекты]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%A2%D0%B5%D1%85%D0%BD%D0%BE%D0%BB%D0%BE%D0%B3%D0%B8%D0%B8_%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F_(10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=3896</id>
		<title>Категория:Технологии программирования (10 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%A2%D0%B5%D1%85%D0%BD%D0%BE%D0%BB%D0%BE%D0%B3%D0%B8%D0%B8_%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F_(10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=3896"/>
		<updated>2013-06-18T17:52:03Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Готовые лабораторные работы */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;p&amp;gt;{{Предмет | name=Технологии программирования | prepod=[[Тарнакин А.О.]] | lections=? | seminars=нет | labs=3 | dzs=? | rks=? | signif=по желанию | what=экзамен}}&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Технологии программирования. А конкретно - [http://ru.wikipedia.org/wiki/Java Java].&lt;br /&gt;
__TOC__&lt;br /&gt;
== Лекции ==&lt;br /&gt;
&lt;br /&gt;
За явкой следить не будут. Вики-конспектов не будет, потому что лекции даются не для конспектирования. Весь материал [[#Литература | тут]].&lt;br /&gt;
&lt;br /&gt;
== Лабораторные работы ==&lt;br /&gt;
&lt;br /&gt;
Всего 3 лабораторных.&lt;br /&gt;
&lt;br /&gt;
Выполняются на языке Java. ПО для разработки можно загрузить [http://www.oracle.com/technetwork/java/javase/downloads/index.html здесь]. Необходимы &amp;lt;code&amp;gt;JRE&amp;lt;/code&amp;gt; и &amp;lt;code&amp;gt;JDK&amp;lt;/code&amp;gt;. В качестве &amp;lt;code&amp;gt;IDE&amp;lt;/code&amp;gt; вполне хватит &amp;lt;code&amp;gt;NetBeans&amp;lt;/code&amp;gt;. Сервером приложений лучше выбрать &amp;lt;code&amp;gt;Apache Tomcat&amp;lt;/code&amp;gt;, а не &amp;lt;code&amp;gt;GlassFish&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Как можно заметить, описания работ даны в очень общем виде, без подробных требований. По этому поводу прямая речь от преподавателя: &amp;lt;blockquote&amp;gt;&#039;&#039;Задания умышленно не детализирую, мне интересно посмотреть на ваше творчество.&#039;&#039;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Сдача лабораторных (и курсовой) происходит по принципу &amp;quot;чем раньше - тем проще&amp;quot;. В начале вообще по коду ничего отвечать не надо и нет дополнительных заданий. Но начиная где-то с мая сдать станет ощутимо сложнее.&lt;br /&gt;
&lt;br /&gt;
=== Лабораторная работа №1 ===&lt;br /&gt;
&lt;br /&gt;
Работа с базовыми классами стандартных пакетов &amp;lt;code&amp;gt;java.io&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;java.net&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;java.util&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Задание:&lt;br /&gt;
* необходимо получить содержимое web-странички, проиндексировать слова в нём (в содержимом) и результаты сохранить в файл;&lt;br /&gt;
* программа должна быть исполнена в виде консольного приложения, позволяющего выбирать адрес web-страницы и имя файла, в который будут сохранены результаты;&lt;br /&gt;
* программу необходимо компилировать и запускать без помощи IDE (но сам код можно писать и в IDE).&lt;br /&gt;
&lt;br /&gt;
Ссылки по теме:&lt;br /&gt;
* [http://en.wikibooks.org/wiki/Java_Programming/Understanding_a_Java_Program как устроена Java-программа];&lt;br /&gt;
* [http://www.skipy.ru/technics/likbez.html#hello компиляция и запуск из консоли Windows];&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/essential/io/ основы ввода/вывода];&lt;br /&gt;
* [http://docs.oracle.com/javase/6/docs/api/java/net/package-summary.html#package_description работа с сетью];&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/collections/index.html контейнерные классы].&lt;br /&gt;
&lt;br /&gt;
=== Лабораторная работа №2 ===&lt;br /&gt;
&lt;br /&gt;
Выполняется на базе ЛР №1.&lt;br /&gt;
&lt;br /&gt;
Работа с БД, многопоточность, синхронизация, журналирование.&lt;br /&gt;
&lt;br /&gt;
Задание:&lt;br /&gt;
* программа должна быть выполнена как многопоточное приложение, использующее &amp;lt;code&amp;gt;java.util.concurrent&amp;lt;/code&amp;gt; и позволяющее ограничивать загрузку процессора;&lt;br /&gt;
* индексация каждой странички должна производиться в отдельном потоке, содержимое сохранять в БД тройками вида &#039;&#039;&#039;&amp;lt;code&amp;gt;слово - частота упоминания на странице - страница&amp;lt;/code&amp;gt;&#039;&#039;&#039;. Найденные на страничке ссылки (&#039;&#039;&#039;&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;href=&amp;quot;http://...&amp;quot;&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&#039;&#039;&#039;) должны обрабатываться отличным от текущего потоком;&lt;br /&gt;
* программа должна выполнять поиск по словам и выводить адреса проиндексированных ранее страничек в порядке, пропорциональном частоте появления слова на страничке;&lt;br /&gt;
* программа должна писать отладочные сообщения посредством стандартных механизмов [http://ru.wikipedia.org/wiki/Slf4J SLF4J].&lt;br /&gt;
&lt;br /&gt;
Ссылки по теме:&lt;br /&gt;
* драйвера для работы с БД:&lt;br /&gt;
** [http://jdbc.postgresql.org/ PostgreSQL];&lt;br /&gt;
** [http://www.mysql.com/products/connector/ MySQL];&lt;br /&gt;
** [http://hsqldb.org/ HyperSQL];&lt;br /&gt;
* [http://en.wikipedia.org/wiki/Java_Database_Connectivity работа с БД];&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/essential/concurrency/index.html многопоточность];&lt;br /&gt;
** [http://docs.oracle.com/javase/tutorial/essential/concurrency/highlevel.html синхронизация потоков] (чтобы не писать свой велосипед);&lt;br /&gt;
* [http://www.rsdn.ru/forum/java/3622844.1 вопросы для самоконтроля].&lt;br /&gt;
&lt;br /&gt;
=== Лабораторная работа №3 ===&lt;br /&gt;
&lt;br /&gt;
Выполняется на базе ЛР №2.&lt;br /&gt;
&lt;br /&gt;
Создание web-сервисов.&lt;br /&gt;
&lt;br /&gt;
Задание:&lt;br /&gt;
* программа должна быть выполнена в виде web-приложения, индексирующего в фоновом режиме содержимое страничек, и обрабатывать поисковые запросы посредством [http://ru.wikipedia.org/wiki/REST REST] web-сервиса.&lt;br /&gt;
&lt;br /&gt;
Ссылки по теме:&lt;br /&gt;
* [http://habrahabr.ru/post/38730/ архитектура REST];&lt;br /&gt;
* [http://www.devx.com/Java/Article/42873 RESTful веб-сервисы и Java];&lt;br /&gt;
* [http://docs.jboss.org/resteasy/docs/1.1.GA/userguide/html_single/index.html руководство по работе с RESTful веб-сервисами на Java] - перечислены все методы и их параметры;&lt;br /&gt;
* [http://javadev.ru/Eclipse_Web_Tools_Platform/ пример создания веб-приложения с сервлетом] - очень помогает разобраться, только не надо делать оттуда всё подряд. Всё необходимое находится в итерациях 2 и 3, где про сервлет и класс &amp;lt;code&amp;gt;Database&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://jersey.java.net/use/getting-started.html Jersey] и [http://jersey.java.net/nonav/documentation/latest/user-guide.html документация по Jersey];&lt;br /&gt;
* [http://www.blogsoncloud.com/jsp/blogs/restful-web-service-using-jersey.jsp пример создания веб-сервиса с Jersey] - используется &amp;lt;code&amp;gt;Eclipse&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://www.vogella.com/articles/REST/article.html и ещё один пример веб-службы на Jersey] - также используется &amp;lt;code&amp;gt;Eclipse&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://vichargrave.com/restful-web-service-development-with-netbeans-and-tomcat-tutorial/ ещё один пример с Jersey] - используется &amp;lt;code&amp;gt;NetBeans&amp;lt;/code&amp;gt; и &amp;lt;code&amp;gt;Tomcat&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://forum.vingrad.ru/forum/topic-242617/kw-restful-jax--maven-jersey.html веб-сервис на Maven].&lt;br /&gt;
&lt;br /&gt;
Если решите делать на [http://ru.wikipedia.org/wiki/SOAP SOAP] - передумайте обратно. [[Тарнакин А.О. | Тарнакин]] и все правильные чуваки не одобряют.&lt;br /&gt;
&lt;br /&gt;
=== Готовые лабораторные работы ===&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 ! Год !! Вариант исполнения !! Работа !! Описание !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || 1 || ЛР №1 || сбор только русских слов через RegExp&amp;lt;br&amp;gt;Notepad++, командная строка || [http://yadi.sk/d/14F6O7jx2vpNM загрузить]&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || 1 || ЛР №2 || СУБД PostgreSQL (схема БД есть), настройки из config.ini&amp;lt;br&amp;gt;NetBeans || [http://yadi.sk/d/GbiQltGJ4CGK5 загрузить]&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || 1 || ЛР №3 || СУБД PostgreSQL (схема БД из ЛР №2)&amp;lt;br&amp;gt;NetBeans, Apache Tomcat || [http://yadi.sk/d/HQi0_xfK3nKxa загрузить]&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || 2 || все || Описание доступно по ссылке || [https://github.com/zhukovRoman/Java github]&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || 3 || все || СУБД PostgreSQL (схема БД прилагается)&amp;lt;br&amp;gt;NetBeans, GlassFish || [http://yadi.sk/d/qAFbbk2M3plxW загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Курсовая работа ==&lt;br /&gt;
&lt;br /&gt;
Страница курсовой работы находится [[Курсовая по ТП (10 семестр) | здесь]].&lt;br /&gt;
&lt;br /&gt;
== Экзамен ==&lt;br /&gt;
&lt;br /&gt;
В билете два вопроса.&lt;br /&gt;
&lt;br /&gt;
* [http://yadi.sk/d/ciqV8cTk5Dpci вопросы к экзамену]&lt;br /&gt;
* [http://yadi.sk/d/GQnCmFq95nemq ответы на вопросы]&lt;br /&gt;
&lt;br /&gt;
== Литература ==&lt;br /&gt;
&lt;br /&gt;
* Хорстман, Корнел - &amp;quot;Java 2&amp;quot;;&lt;br /&gt;
* [http://en.wikibooks.org/wiki/Subject:Java_programming_language Википедия].&lt;br /&gt;
&lt;br /&gt;
[[Категория:10 семестр]]&lt;br /&gt;
[[Категория:Предметы]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</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=3870</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=3870"/>
		<updated>2013-06-16T11:53:41Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Билет 21 */&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;
Странно, что ни в одном билете нет запроса с сортировкой результатов. Возможно, они буду в дополнительных заданиях.&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;
В трёх билетах в задании на запрос встречается формулировка &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;
=== Билет 1 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj SPJX&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = SPJX.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
  S2&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 2 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, поставляемых более чем одним поставщиком.&lt;br /&gt;
&lt;br /&gt;
Текст запроса, каким его дал Григорьев на лекции, впоследствии исправив его:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       SUM(kolichestvo) AS &amp;quot;Сколько штук поставляется&amp;quot;,&lt;br /&gt;
       COUNT(DISTINCT nomer_postavshika) AS &amp;quot;Сколько у неё поставщиков&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       kol AS &amp;quot;Сколько штук поставляется&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT nomer_detali,&lt;br /&gt;
             SUM(kolichestvo) AS kol,&lt;br /&gt;
             COUNT(DISTINCT nomer_postavshika)&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1&lt;br /&gt;
     ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Сколько штук поставляется | Сколько у неё поставщиков&lt;br /&gt;
 --------------+---------------------------+---------------------------&lt;br /&gt;
  P1           |                        71 |                         5&lt;br /&gt;
  P10          |                         3 |                         2&lt;br /&gt;
  P11          |                         5 |                         2&lt;br /&gt;
  P12          |                        13 |                         7&lt;br /&gt;
  P14          |                      9036 |                         4&lt;br /&gt;
  P15          |                         7 |                         3&lt;br /&gt;
  P16          |                        46 |                         3&lt;br /&gt;
  P17          |                      3122 |                         3&lt;br /&gt;
  P2           |                        68 |                         4&lt;br /&gt;
  P21          |                        27 |                         4&lt;br /&gt;
  P4           |                        10 |                         2&lt;br /&gt;
  P5           |                        16 |                         2&lt;br /&gt;
 (12 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 3 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, поставляющих детали с номером &#039;P1&#039; для какого-либо изделия в количестве (в поставке) большим, чем средний объём поставок деталей с номером &#039;P2&#039; для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT X.nomer_postavshika &lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE X.nomer_detali = &#039;P1&#039;&lt;br /&gt;
  AND X.kolichestvo &amp;gt; (&lt;br /&gt;
                       SELECT AVG(kolichestvo)&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                         AND nomer_detali = &#039;P2&#039;&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT *&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      WHERE nomer_izdelia IN(&lt;br /&gt;
                             SELECT nomer_izdelia&lt;br /&gt;
                             FROM spasoi_ekz.spj&lt;br /&gt;
                             WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                            )&lt;br /&gt;
        AND nomer_izdelia IN(&lt;br /&gt;
	                     SELECT nomer_izdelia&lt;br /&gt;
	                     FROM spasoi_ekz.spj&lt;br /&gt;
	                     WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
	                    )&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE nomer_detali = &#039;P1&#039; AND kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM (&lt;br /&gt;
       SELECT *&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       WHERE nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                             )&lt;br /&gt;
         AND nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
                             )&lt;br /&gt;
      ) B&lt;br /&gt;
 WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 4 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий, для которых детали поставляет только поставщик с номером ‘S1’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                    AND X.nomer_izdelia = nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE nomer_izdelia IN(&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                      )&lt;br /&gt;
  AND nomer_izdelia NOT IN(&lt;br /&gt;
                           SELECT nomer_izdelia&lt;br /&gt;
                           FROM spasoi_ekz.spj&lt;br /&gt;
                           WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                          );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_izdelia&lt;br /&gt;
 ---------------&lt;br /&gt;
  J5&lt;br /&gt;
  J16&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 5 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &amp;quot;Болт&amp;quot; в количестве (в поставке) большим, чем средний объём всех поставок деталей с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                           ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                           ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                              AND nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika IN (&lt;br /&gt;
                            SELECT nomer_postavshika&lt;br /&gt;
                            FROM spasoi_ekz.spj&lt;br /&gt;
                            WHERE nomer_detali = (&lt;br /&gt;
                                                  SELECT nomer_detali&lt;br /&gt;
                                                  FROM spasoi_ekz.p&lt;br /&gt;
                                                  WHERE LOWER(nazvanie) = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                                                 )&lt;br /&gt;
                              AND kolichestvo &amp;gt; (&lt;br /&gt;
                                                 SELECT AVG(kolichestvo)&lt;br /&gt;
                                                 FROM spasoi_ekz.spj&lt;br /&gt;
                                                 WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                                                )&lt;br /&gt;
                           );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------&lt;br /&gt;
  Оша&lt;br /&gt;
  Иванов&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 6 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, поставляемых поставщиком, проживающим в том же городе, где изготавливаются эти детали, для изделия с названием ‘Велосипед 01/23’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01/23&#039;);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.S S, spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
  AND nomer_izdelia = (&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.j&lt;br /&gt;
                       WHERE nazvanie = LOWER(&#039;Велосипед 01/23&#039;)&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie&lt;br /&gt;
 ----------&lt;br /&gt;
  рама&lt;br /&gt;
  колесо&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 7 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входят детали с названием &#039;Болт&#039;, поставляемых поставщиками с именем &#039;Иванов&#039;, в количестве (в поставке) большим, чем средний объём поставок для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj X&lt;br /&gt;
                     WHERE SPJ.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j&lt;br /&gt;
WHERE nomer_izdelia IN (&lt;br /&gt;
                        SELECT nomer_izdelia&lt;br /&gt;
                        FROM (spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                                      AND imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                                                 JOIN spasoi_ekz.p P&lt;br /&gt;
                                                   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                      AND nazvanie = LOWER(&#039;Болт&#039;)) A&lt;br /&gt;
                        WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                                             SELECT AVG(kolichestvo)&lt;br /&gt;
                                             FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                                       ON SPJ.nomer_izdelia = A.nomer_izdelia&lt;br /&gt;
                                            )&lt;br /&gt;
                       );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант этого же запроса, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT J.nazvanie, kolichestvo&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
        AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
        AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
        AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
        AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM spasoi_ekz.spj&lt;br /&gt;
 WHERE nomer_izdelia IN(&lt;br /&gt;
                        SELECT J.nomer_izdelia&lt;br /&gt;
                        FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
                        WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                          AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                          AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                          AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                          AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                       )&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 -------------------&lt;br /&gt;
  шкаф&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 8 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий и общее количество деталей для них, поставляемых поставщиками с именем &#039;Петров&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia AS &amp;quot;Номер изделия&amp;quot;, SUM(kolichestvo) AS &amp;quot;Количество деталей&amp;quot; &lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                             -- так как &amp;quot;поставщикАМИ&amp;quot; и возможны&lt;br /&gt;
                             -- Иван Петров и Петров Иван, то LIKE %Петров%&lt;br /&gt;
                             AND imya LIKE &#039;%Петров%&#039;&lt;br /&gt;
GROUP BY nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер изделия | Количество деталей&lt;br /&gt;
 ---------------+--------------------&lt;br /&gt;
  J4            |                101&lt;br /&gt;
  J3            |                  6&lt;br /&gt;
  J13           |                  9&lt;br /&gt;
  J15           |                 40&lt;br /&gt;
  J1            |                  3&lt;br /&gt;
  J12           |                 15&lt;br /&gt;
  J14           |                 93&lt;br /&gt;
 (7 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 9 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, которые входят только в одно изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, kol FROM (&lt;br /&gt;
       SELECT nomer_detali, SUM(kolichestvo) AS kol, COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
    ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali | sum&lt;br /&gt;
 --------------+------&lt;br /&gt;
  P10          |    3&lt;br /&gt;
  P11          |    5&lt;br /&gt;
  P12          |   13&lt;br /&gt;
  P13          |   14&lt;br /&gt;
  P17          | 3122&lt;br /&gt;
  P18          |    9&lt;br /&gt;
  P19          |    1&lt;br /&gt;
  P20          |    4&lt;br /&gt;
  P21          |   27&lt;br /&gt;
  P22          |    9&lt;br /&gt;
  P23          |  101&lt;br /&gt;
  P24          |    1&lt;br /&gt;
  P25          |    1&lt;br /&gt;
  P26          |    1&lt;br /&gt;
  P3           |   50&lt;br /&gt;
  P4           |   10&lt;br /&gt;
  P6           |   20&lt;br /&gt;
  P7           |    5&lt;br /&gt;
  P8           |   25&lt;br /&gt;
  P9           |    1&lt;br /&gt;
 (20 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 10 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &#039;Болт&#039; для изделия с названием &#039;Рама 02-01&#039; в количестве (в поставке) большим, чем минимальное значение поставки детали с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
			   ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			      AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.p P&lt;br /&gt;
			   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
			      AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.s S&lt;br /&gt;
			   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
		     SELECT MIN(kolichestvo)&lt;br /&gt;
		     FROM spasoi_ekz.spj &lt;br /&gt;
		     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Русе Болтон&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 11 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия городов и суммарное состояние проживающих в каждом городе поставщиков, у которых минимальный объём поставки деталей больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s S&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;
&amp;lt;!-- а этот запрос выполняет не совсем то и не правильно&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, sost&lt;br /&gt;
FROM (&lt;br /&gt;
SELECT gorod, SUM(sostoyanie) AS sost, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj, spasoi_ekz.s&lt;br /&gt;
WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
GROUP BY S.gorod HAVING SUM(SPJ.kolichestvo) &amp;gt; 1000&lt;br /&gt;
) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt; &lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    gorod   |   sum&lt;br /&gt;
 -----------+---------&lt;br /&gt;
  Прага     | 2111110&lt;br /&gt;
  Стокгольм |  888888&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 12 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей, поставляемых для какого-либо изделия поставщиком, проживающим в том же городе, где изготавливается это изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali&lt;br /&gt;
FROM spasoi_ekz.spj SPJ, spasoi_ekz.s S, spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND S.gorod = J.gorod&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali&lt;br /&gt;
 --------------&lt;br /&gt;
  P15&lt;br /&gt;
  P16&lt;br /&gt;
  P26&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 13 ===&lt;br /&gt;
&lt;br /&gt;
Написать &amp;lt;u&amp;gt;один&amp;lt;/u&amp;gt; запрос SELECT: выдать количества строк в таблице S (Поставщик) 1) с пустыми значениями и 2) непустыми значениями в столбце Состояние.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT COUNT(*) - COUNT(sostoyanie) AS &amp;quot;С пустым состоянием&amp;quot;, &lt;br /&gt;
       COUNT(sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SELECT COUNT(Snull.*) AS &amp;quot;С пустым состоянием&amp;quot;, COUNT(Snotnull.sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s Snull RIGHT OUTER JOIN spasoi_ekz.s Snotnull&lt;br /&gt;
                                      ON Snull.nomer_postavshika = Snotnull.nomer_postavshika&lt;br /&gt;
                                         AND Snull.sostoyanie IS NULL;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  С пустым состоянием | С не пустым состоянием&lt;br /&gt;
 ---------------------+-----------------------&lt;br /&gt;
                    2 |                    16&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 14 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют детали только и только для изделия с номером &#039;J1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.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;
			(&lt;br /&gt;
				nomer_izdelia != &#039;J18&#039; AND &lt;br /&gt;
				nomer_postavshika  = s.nomer_postavshika &lt;br /&gt;
			)&lt;br /&gt;
		OR&lt;br /&gt;
			(&lt;br /&gt;
				nomer_izdelia = &#039;J18&#039; 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;
&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;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 ----------------&lt;br /&gt;
  Безликий&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 15 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования изделий, для которых детали поставляют только те поставщики, у которых состояние больше 1000000 у.е.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
		  SELECT *&lt;br /&gt;
		  FROM spasoi_ekz.spj X JOIN spasoi_ekz.s S&lt;br /&gt;
		                          ON X.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
		  WHERE sostoyanie &amp;lt;= 1000000&lt;br /&gt;
		  AND X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Вариант этого запроса без NOT EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000000&lt;br /&gt;
  AND SPJ.nomer_izdelia NOT IN (&lt;br /&gt;
                                SELECT nomer_izdelia&lt;br /&gt;
                                FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                WHERE sostoyanie &amp;lt; 1000000&lt;br /&gt;
                               );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
  уникальное изделие&lt;br /&gt;
  процессор&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 16 ===&lt;br /&gt;
Написать запрос SELECT: выдать цвета и для каждого цвета общее количество деталей, входящих в изделие с названием &#039;Панно 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT cvet AS &amp;quot;Цвет&amp;quot;, SUM(kolichestvo) AS &amp;quot;Деталей&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			     AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
			JOIN spasoi_ekz.P P&lt;br /&gt;
			  ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
GROUP BY cvet;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&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;, 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;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_postavshika AS &amp;quot;Номер поставщика&amp;quot;, COUNT(*) AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE (&lt;br /&gt;
       SELECT AVG(kolichestvo)&lt;br /&gt;
       FROM spasoi_ekz.spj X&lt;br /&gt;
       WHERE X.nomer_postavshika = spj.nomer_postavshika&lt;br /&gt;
       ) &amp;gt; 1000&lt;br /&gt;
GROUP BY nomer_postavshika;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nom AS &amp;quot;Номер поставщика&amp;quot;, cnt AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT S.nomer_postavshika AS nom,&lt;br /&gt;
             COUNT(SPJ.nomer_postavshika) AS cnt,&lt;br /&gt;
             AVG(SPJ.kolichestvo) AS kol&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
      GROUP BY S.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kol &amp;gt; 1000;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер поставщика | Количество поставок&lt;br /&gt;
 ------------------+---------------------&lt;br /&gt;
  S13              |                   1&lt;br /&gt;
  S6               |                   7&lt;br /&gt;
  S14              |                   1&lt;br /&gt;
  S15              |                   1&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 18 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, имеющих состояние больше 1000 и поставляющих деталь с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем средний объём поставки, выполненной поставщиками с именем &#039;Иванов&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:2nd dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Второй по сложности запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;4px&amp;quot;&amp;gt;&#039;&#039;&#039;Вот уж не свезло, так не свезло&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                       ON SPJ.nomer_postavshika = S.nomer_postavshika &lt;br /&gt;
                     WHERE S.imya = &#039;Иванов&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 19 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия красных деталей, которые входят только в изделие с названием &#039;Рама 02-03&#039; в количестве, меньшем 10 единиц в поставке.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT X.nazvanie&lt;br /&gt;
FROM spasoi_ekz.p X JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_detali = X.nomer_detali&lt;br /&gt;
WHERE X.cvet = &#039;красный&#039;&lt;br /&gt;
  AND kolichestvo &amp;lt; 10&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                                        ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                    AND X.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                              AND J.nazvanie = LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;lt; 10&lt;br /&gt;
  AND SPJ.nomer_detali NOT IN (&lt;br /&gt;
                               SELECT nomer_detali&lt;br /&gt;
                               FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                         ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                            AND J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 ----------------&lt;br /&gt;
  усиленная рама&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 20 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих только белые детали.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                            ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                  WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    AND P.cvet != &#039;белый&#039;&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;белый&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE S.nomer_postavshika NOT IN (&lt;br /&gt;
                                  SELECT nomer_postavshika&lt;br /&gt;
                                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                                            ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                               AND cvet != &#039;белый&#039;&lt;br /&gt;
                                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika NOT IN  (&lt;br /&gt;
                                 SELECT spj.nomer_postavshika&lt;br /&gt;
                                 FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                                 WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                   AND p.cvet != &#039;белый&#039;&lt;br /&gt;
                                )&lt;br /&gt;
  AND nomer_postavshika  IN (&lt;br /&gt;
                             SELECT spj.nomer_postavshika&lt;br /&gt;
                             FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                             WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                               AND p.cvet = &#039;белый&#039;&lt;br /&gt;
                            );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 -----------------&lt;br /&gt;
  Рендилл Тарли&lt;br /&gt;
  Сэмвелл Тарли&lt;br /&gt;
  Мелисса Флорент&lt;br /&gt;
  Томми Версетти&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 21 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, для которых детали поставляет только и только поставщик с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Чтобы продемонстрировать выполнение запроса наглядно, возьмём поставщика не &#039;S1&#039;, а &#039;S18&#039;, который был создан специально для этого запроса. Если оставить &#039;S1&#039;, то наглядности не получится, так как по нашей схеме БД этот поставщик не попадает под условие &amp;quot;&#039;&#039;только и только&#039;&#039;&amp;quot;, и запрос вернёт пустой результат.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM  spasoi_ekz.SPJ SPJ&lt;br /&gt;
WHERE &lt;br /&gt;
  NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S18&#039; AND nomer_izdelia = SPJ.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; AND nomer_izdelia != SPJ.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кинжал&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 22 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют только детали с номером &#039;P1&#039; для изделия с именем &#039;Штуцер 01-02&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj X JOIN spasoi_ekz.j J&lt;br /&gt;
                                          ON X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE X.nomer_detali != &#039;P1&#039; &lt;br /&gt;
                    AND j.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                    AND S.nomer_postavshika = X.nomer_postavshika&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- неверный запрос - номер изделия, а не название&lt;br /&gt;
SELECT imya FROM S X&lt;br /&gt;
JOIN SPJ Y ON X.nomer_postavshika=Y.nomer_postavshika&lt;br /&gt;
WHERE X.nomer_postavshika NOT IN (&lt;br /&gt;
                  SELECT DISTINCT nomer_postavshika FROM SPJ Z&lt;br /&gt;
                  WHERE Z.nomer_izdelia != &#039;Штуцер 01-02&#039;&lt;br /&gt;
                  AND Z.nomer_detali!=&#039;P1&#039;);--&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND SPJ.nomer_detali = &#039;P1&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE SPJ.nomer_postavshika NOT IN (&lt;br /&gt;
                                    SELECT nomer_postavshika&lt;br /&gt;
                                    FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                              ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                                 AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                                                            JOIN spasoi_ekz.p P&lt;br /&gt;
                                                              ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                                 AND SPJ.nomer_detali != &#039;P1&#039;&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Иван&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 23 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют деталь с названием &#039;Винт&#039; в количестве большим 100 единиц в одной поставке и имеют состояние больше среднего по их родному городу.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Винт&#039;)&lt;br /&gt;
  AND SPJ.kolichestvo &amp;gt; 100&lt;br /&gt;
  AND S.sostoyanie &amp;gt; (&lt;br /&gt;
                      SELECT AVG(SS.sostoyanie)&lt;br /&gt;
                      FROM spasoi_ekz.s SS&lt;br /&gt;
                      WHERE SS.gorod = S.gorod&lt;br /&gt;
                     );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 24 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в одном городе.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- С этим запросом возникла неожиданная проблема - задание то ли неполное, то ли неправильное, потому что нельзя однозначно сказать, что по нему требуется сделать.&lt;br /&gt;
&lt;br /&gt;
Так что тут несколько вариантов запросов (кто как понял).&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Первый вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, kol&lt;br /&gt;
FROM spasoi_ekz.p A, (&lt;br /&gt;
                      SELECT X.gorod, SUM(kolichestvo) as kol&lt;br /&gt;
                      FROM spasoi_ekz.p X, spasoi_ekz.spj Y&lt;br /&gt;
                      WHERE Y.nomer_detali = X.nomer_detali&lt;br /&gt;
                      GROUP BY X.gorod&lt;br /&gt;
                     ) B&lt;br /&gt;
WHERE A.gorod = B.gorod;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
        nazvanie       | kol&lt;br /&gt;
 ----------------------+------&lt;br /&gt;
  подставка            |    9&lt;br /&gt;
  стойка               |    9&lt;br /&gt;
  абажур               |    9&lt;br /&gt;
  гайка                |  139&lt;br /&gt;
  ось                  |   60&lt;br /&gt;
  зубчатое колесо      |   60&lt;br /&gt;
  транзистор           |   50&lt;br /&gt;
  печатная плата       |   50&lt;br /&gt;
  диод                 |   50&lt;br /&gt;
  универсальная деталь |   13&lt;br /&gt;
  уникальная деталь    |   14&lt;br /&gt;
  болт                 | 9137&lt;br /&gt;
  рама                 |   69&lt;br /&gt;
  колесо               |   69&lt;br /&gt;
  втулка               |   69&lt;br /&gt;
  бумага               | 3122&lt;br /&gt;
  плитка               |   14&lt;br /&gt;
  орнамент             |   14&lt;br /&gt;
  уголок               |   14&lt;br /&gt;
  гайка 01-01          |   27&lt;br /&gt;
  усиленная рама       |   10&lt;br /&gt;
  винт                 | 9137&lt;br /&gt;
  труселя              |    1&lt;br /&gt;
  штуцерная деталь     |   10&lt;br /&gt;
  шуруп                |  139&lt;br /&gt;
 (25 rows)&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
и --&amp;gt;&lt;br /&gt;
В уточнение задания Григорьев сказал следующее: &amp;quot;&#039;&#039;Следует учесть, что в качестве наименования города может выступать переменная, в которую в некоторой программе должно быть занесено конкретное значение перед выполнением запроса&#039;&#039;&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
То есть, вообще говоря, задание на запрос неполное, и его можно трактовать так: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в городе &amp;lt;code&amp;gt;%НАЗВАНИЕГОРОДА%&amp;lt;/code&amp;gt;. Вот эта переменная задаётся где-то в программе, а в БД идёт запрос с уже подставленным конкретным названием. &lt;br /&gt;
&lt;br /&gt;
Этот вариант запроса составлен, например, для Лондона. &lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
WHERE gorod = &#039;Лондон&#039;&lt;br /&gt;
GROUP BY nazvanie;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie | sum&lt;br /&gt;
 ----------+-----&lt;br /&gt;
  гайка    |  71&lt;br /&gt;
  шуруп    |  68&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 25 ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих хотя бы одну белую деталь для изделия с названием &#039;Велосипед 01-04&#039; с объёмом поставки большим, чем средний объём поставки этого поставщика.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ&lt;br /&gt;
                     WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 26 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера красных деталей и количество поставок этих деталей.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY P.nomer_detali;   &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос через JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT SPJ.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY SPJ.nomer_detali;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Количество поставок с ней&lt;br /&gt;
 --------------+---------------------------&lt;br /&gt;
  P15          |                         3&lt;br /&gt;
  P22          |                         1&lt;br /&gt;
  P24          |                         1&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 27 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования городов и среднее состояние поставщиков для каждого города, поставляющих детали с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем минимальный объём поставки, выполненной поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:1st dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;7px&amp;quot;&amp;gt;&#039;&#039;&#039;Сложнейший запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Сохрани Джа, вытащить такое&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.gorod AS &amp;quot;Город&amp;quot;, AVG(S.sostoyanie) AS &amp;quot;Среднее состояние&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT MIN(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                    )&lt;br /&gt;
GROUP BY S.gorod;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    Город   |   Среднее состояние&lt;br /&gt;
 -----------+-----------------------&lt;br /&gt;
  Мытищи    |    35000.500000000000&lt;br /&gt;
  Йокогама  |  1500000.000000000000&lt;br /&gt;
  Манчестер | 2571.0000000000000000&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 28 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входит хотя бы одна красная деталь весом больше 10 граммов, поставляемая только поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ1&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ1.nomer_izdelia&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ1.nomer_detali&lt;br /&gt;
WHERE P.ves &amp;gt; 10&lt;br /&gt;
 AND P.cvet = &#039;красный&#039;&lt;br /&gt;
 AND NOT EXISTS (&lt;br /&gt;
                 SELECT SPJ2.nomer_postavshika&lt;br /&gt;
                 FROM spasoi_ekz.spj SPJ2         &lt;br /&gt;
                 WHERE SPJ2.nomer_detali = P.nomer_detali&lt;br /&gt;
	 	   AND SPJ2.nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                );                     &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 -----------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 29 ===&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, которые входят только и только в состав изделия с названием &#039;Штуцер 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.p P&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT SPJ.nomer_izdelia&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                            ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                  WHERE (&lt;br /&gt;
                         J.nazvanie != LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                     OR (&lt;br /&gt;
                         J.nazvanie = LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali != P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 ------------------&lt;br /&gt;
  штуцерная деталь&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 30 ===&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------------&lt;br /&gt;
  Оша&lt;br /&gt;
  Бран Старк&lt;br /&gt;
 (2 rows)&lt;br /&gt;
[[Категория:Структурное проектирование АСОИ (10 семестр)]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</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=3869</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=3869"/>
		<updated>2013-06-16T11:53:19Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Билет 21 */  Номер изделия хранится в SPJ так же как и в J&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;
Странно, что ни в одном билете нет запроса с сортировкой результатов. Возможно, они буду в дополнительных заданиях.&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;
В трёх билетах в задании на запрос встречается формулировка &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;
=== Билет 1 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj SPJX&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = SPJX.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
  S2&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 2 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, поставляемых более чем одним поставщиком.&lt;br /&gt;
&lt;br /&gt;
Текст запроса, каким его дал Григорьев на лекции, впоследствии исправив его:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       SUM(kolichestvo) AS &amp;quot;Сколько штук поставляется&amp;quot;,&lt;br /&gt;
       COUNT(DISTINCT nomer_postavshika) AS &amp;quot;Сколько у неё поставщиков&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       kol AS &amp;quot;Сколько штук поставляется&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT nomer_detali,&lt;br /&gt;
             SUM(kolichestvo) AS kol,&lt;br /&gt;
             COUNT(DISTINCT nomer_postavshika)&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1&lt;br /&gt;
     ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Сколько штук поставляется | Сколько у неё поставщиков&lt;br /&gt;
 --------------+---------------------------+---------------------------&lt;br /&gt;
  P1           |                        71 |                         5&lt;br /&gt;
  P10          |                         3 |                         2&lt;br /&gt;
  P11          |                         5 |                         2&lt;br /&gt;
  P12          |                        13 |                         7&lt;br /&gt;
  P14          |                      9036 |                         4&lt;br /&gt;
  P15          |                         7 |                         3&lt;br /&gt;
  P16          |                        46 |                         3&lt;br /&gt;
  P17          |                      3122 |                         3&lt;br /&gt;
  P2           |                        68 |                         4&lt;br /&gt;
  P21          |                        27 |                         4&lt;br /&gt;
  P4           |                        10 |                         2&lt;br /&gt;
  P5           |                        16 |                         2&lt;br /&gt;
 (12 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 3 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, поставляющих детали с номером &#039;P1&#039; для какого-либо изделия в количестве (в поставке) большим, чем средний объём поставок деталей с номером &#039;P2&#039; для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT X.nomer_postavshika &lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE X.nomer_detali = &#039;P1&#039;&lt;br /&gt;
  AND X.kolichestvo &amp;gt; (&lt;br /&gt;
                       SELECT AVG(kolichestvo)&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                         AND nomer_detali = &#039;P2&#039;&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT *&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      WHERE nomer_izdelia IN(&lt;br /&gt;
                             SELECT nomer_izdelia&lt;br /&gt;
                             FROM spasoi_ekz.spj&lt;br /&gt;
                             WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                            )&lt;br /&gt;
        AND nomer_izdelia IN(&lt;br /&gt;
	                     SELECT nomer_izdelia&lt;br /&gt;
	                     FROM spasoi_ekz.spj&lt;br /&gt;
	                     WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
	                    )&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE nomer_detali = &#039;P1&#039; AND kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM (&lt;br /&gt;
       SELECT *&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       WHERE nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                             )&lt;br /&gt;
         AND nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
                             )&lt;br /&gt;
      ) B&lt;br /&gt;
 WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 4 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий, для которых детали поставляет только поставщик с номером ‘S1’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                    AND X.nomer_izdelia = nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE nomer_izdelia IN(&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                      )&lt;br /&gt;
  AND nomer_izdelia NOT IN(&lt;br /&gt;
                           SELECT nomer_izdelia&lt;br /&gt;
                           FROM spasoi_ekz.spj&lt;br /&gt;
                           WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                          );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_izdelia&lt;br /&gt;
 ---------------&lt;br /&gt;
  J5&lt;br /&gt;
  J16&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 5 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &amp;quot;Болт&amp;quot; в количестве (в поставке) большим, чем средний объём всех поставок деталей с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                           ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                           ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                              AND nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika IN (&lt;br /&gt;
                            SELECT nomer_postavshika&lt;br /&gt;
                            FROM spasoi_ekz.spj&lt;br /&gt;
                            WHERE nomer_detali = (&lt;br /&gt;
                                                  SELECT nomer_detali&lt;br /&gt;
                                                  FROM spasoi_ekz.p&lt;br /&gt;
                                                  WHERE LOWER(nazvanie) = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                                                 )&lt;br /&gt;
                              AND kolichestvo &amp;gt; (&lt;br /&gt;
                                                 SELECT AVG(kolichestvo)&lt;br /&gt;
                                                 FROM spasoi_ekz.spj&lt;br /&gt;
                                                 WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                                                )&lt;br /&gt;
                           );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------&lt;br /&gt;
  Оша&lt;br /&gt;
  Иванов&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 6 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, поставляемых поставщиком, проживающим в том же городе, где изготавливаются эти детали, для изделия с названием ‘Велосипед 01/23’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01/23&#039;);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.S S, spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
  AND nomer_izdelia = (&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.j&lt;br /&gt;
                       WHERE nazvanie = LOWER(&#039;Велосипед 01/23&#039;)&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie&lt;br /&gt;
 ----------&lt;br /&gt;
  рама&lt;br /&gt;
  колесо&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 7 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входят детали с названием &#039;Болт&#039;, поставляемых поставщиками с именем &#039;Иванов&#039;, в количестве (в поставке) большим, чем средний объём поставок для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj X&lt;br /&gt;
                     WHERE SPJ.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j&lt;br /&gt;
WHERE nomer_izdelia IN (&lt;br /&gt;
                        SELECT nomer_izdelia&lt;br /&gt;
                        FROM (spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                                      AND imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                                                 JOIN spasoi_ekz.p P&lt;br /&gt;
                                                   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                      AND nazvanie = LOWER(&#039;Болт&#039;)) A&lt;br /&gt;
                        WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                                             SELECT AVG(kolichestvo)&lt;br /&gt;
                                             FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                                       ON SPJ.nomer_izdelia = A.nomer_izdelia&lt;br /&gt;
                                            )&lt;br /&gt;
                       );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант этого же запроса, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT J.nazvanie, kolichestvo&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
        AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
        AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
        AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
        AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM spasoi_ekz.spj&lt;br /&gt;
 WHERE nomer_izdelia IN(&lt;br /&gt;
                        SELECT J.nomer_izdelia&lt;br /&gt;
                        FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
                        WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                          AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                          AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                          AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                          AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                       )&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 -------------------&lt;br /&gt;
  шкаф&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 8 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий и общее количество деталей для них, поставляемых поставщиками с именем &#039;Петров&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia AS &amp;quot;Номер изделия&amp;quot;, SUM(kolichestvo) AS &amp;quot;Количество деталей&amp;quot; &lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                             -- так как &amp;quot;поставщикАМИ&amp;quot; и возможны&lt;br /&gt;
                             -- Иван Петров и Петров Иван, то LIKE %Петров%&lt;br /&gt;
                             AND imya LIKE &#039;%Петров%&#039;&lt;br /&gt;
GROUP BY nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер изделия | Количество деталей&lt;br /&gt;
 ---------------+--------------------&lt;br /&gt;
  J4            |                101&lt;br /&gt;
  J3            |                  6&lt;br /&gt;
  J13           |                  9&lt;br /&gt;
  J15           |                 40&lt;br /&gt;
  J1            |                  3&lt;br /&gt;
  J12           |                 15&lt;br /&gt;
  J14           |                 93&lt;br /&gt;
 (7 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 9 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, которые входят только в одно изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, kol FROM (&lt;br /&gt;
       SELECT nomer_detali, SUM(kolichestvo) AS kol, COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
    ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali | sum&lt;br /&gt;
 --------------+------&lt;br /&gt;
  P10          |    3&lt;br /&gt;
  P11          |    5&lt;br /&gt;
  P12          |   13&lt;br /&gt;
  P13          |   14&lt;br /&gt;
  P17          | 3122&lt;br /&gt;
  P18          |    9&lt;br /&gt;
  P19          |    1&lt;br /&gt;
  P20          |    4&lt;br /&gt;
  P21          |   27&lt;br /&gt;
  P22          |    9&lt;br /&gt;
  P23          |  101&lt;br /&gt;
  P24          |    1&lt;br /&gt;
  P25          |    1&lt;br /&gt;
  P26          |    1&lt;br /&gt;
  P3           |   50&lt;br /&gt;
  P4           |   10&lt;br /&gt;
  P6           |   20&lt;br /&gt;
  P7           |    5&lt;br /&gt;
  P8           |   25&lt;br /&gt;
  P9           |    1&lt;br /&gt;
 (20 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 10 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &#039;Болт&#039; для изделия с названием &#039;Рама 02-01&#039; в количестве (в поставке) большим, чем минимальное значение поставки детали с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
			   ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			      AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.p P&lt;br /&gt;
			   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
			      AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.s S&lt;br /&gt;
			   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
		     SELECT MIN(kolichestvo)&lt;br /&gt;
		     FROM spasoi_ekz.spj &lt;br /&gt;
		     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Русе Болтон&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 11 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия городов и суммарное состояние проживающих в каждом городе поставщиков, у которых минимальный объём поставки деталей больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s S&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;
&amp;lt;!-- а этот запрос выполняет не совсем то и не правильно&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, sost&lt;br /&gt;
FROM (&lt;br /&gt;
SELECT gorod, SUM(sostoyanie) AS sost, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj, spasoi_ekz.s&lt;br /&gt;
WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
GROUP BY S.gorod HAVING SUM(SPJ.kolichestvo) &amp;gt; 1000&lt;br /&gt;
) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt; &lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    gorod   |   sum&lt;br /&gt;
 -----------+---------&lt;br /&gt;
  Прага     | 2111110&lt;br /&gt;
  Стокгольм |  888888&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 12 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей, поставляемых для какого-либо изделия поставщиком, проживающим в том же городе, где изготавливается это изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali&lt;br /&gt;
FROM spasoi_ekz.spj SPJ, spasoi_ekz.s S, spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND S.gorod = J.gorod&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali&lt;br /&gt;
 --------------&lt;br /&gt;
  P15&lt;br /&gt;
  P16&lt;br /&gt;
  P26&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 13 ===&lt;br /&gt;
&lt;br /&gt;
Написать &amp;lt;u&amp;gt;один&amp;lt;/u&amp;gt; запрос SELECT: выдать количества строк в таблице S (Поставщик) 1) с пустыми значениями и 2) непустыми значениями в столбце Состояние.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT COUNT(*) - COUNT(sostoyanie) AS &amp;quot;С пустым состоянием&amp;quot;, &lt;br /&gt;
       COUNT(sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SELECT COUNT(Snull.*) AS &amp;quot;С пустым состоянием&amp;quot;, COUNT(Snotnull.sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s Snull RIGHT OUTER JOIN spasoi_ekz.s Snotnull&lt;br /&gt;
                                      ON Snull.nomer_postavshika = Snotnull.nomer_postavshika&lt;br /&gt;
                                         AND Snull.sostoyanie IS NULL;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  С пустым состоянием | С не пустым состоянием&lt;br /&gt;
 ---------------------+-----------------------&lt;br /&gt;
                    2 |                    16&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 14 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют детали только и только для изделия с номером &#039;J1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.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;
			(&lt;br /&gt;
				nomer_izdelia != &#039;J18&#039; AND &lt;br /&gt;
				nomer_postavshika  = s.nomer_postavshika &lt;br /&gt;
			)&lt;br /&gt;
		OR&lt;br /&gt;
			(&lt;br /&gt;
				nomer_izdelia = &#039;J18&#039; 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;
&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;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 ----------------&lt;br /&gt;
  Безликий&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 15 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования изделий, для которых детали поставляют только те поставщики, у которых состояние больше 1000000 у.е.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
		  SELECT *&lt;br /&gt;
		  FROM spasoi_ekz.spj X JOIN spasoi_ekz.s S&lt;br /&gt;
		                          ON X.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
		  WHERE sostoyanie &amp;lt;= 1000000&lt;br /&gt;
		  AND X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Вариант этого запроса без NOT EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000000&lt;br /&gt;
  AND SPJ.nomer_izdelia NOT IN (&lt;br /&gt;
                                SELECT nomer_izdelia&lt;br /&gt;
                                FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                WHERE sostoyanie &amp;lt; 1000000&lt;br /&gt;
                               );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
  уникальное изделие&lt;br /&gt;
  процессор&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 16 ===&lt;br /&gt;
Написать запрос SELECT: выдать цвета и для каждого цвета общее количество деталей, входящих в изделие с названием &#039;Панно 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT cvet AS &amp;quot;Цвет&amp;quot;, SUM(kolichestvo) AS &amp;quot;Деталей&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			     AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
			JOIN spasoi_ekz.P P&lt;br /&gt;
			  ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
GROUP BY cvet;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&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;, 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;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_postavshika AS &amp;quot;Номер поставщика&amp;quot;, COUNT(*) AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE (&lt;br /&gt;
       SELECT AVG(kolichestvo)&lt;br /&gt;
       FROM spasoi_ekz.spj X&lt;br /&gt;
       WHERE X.nomer_postavshika = spj.nomer_postavshika&lt;br /&gt;
       ) &amp;gt; 1000&lt;br /&gt;
GROUP BY nomer_postavshika;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nom AS &amp;quot;Номер поставщика&amp;quot;, cnt AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT S.nomer_postavshika AS nom,&lt;br /&gt;
             COUNT(SPJ.nomer_postavshika) AS cnt,&lt;br /&gt;
             AVG(SPJ.kolichestvo) AS kol&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
      GROUP BY S.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kol &amp;gt; 1000;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер поставщика | Количество поставок&lt;br /&gt;
 ------------------+---------------------&lt;br /&gt;
  S13              |                   1&lt;br /&gt;
  S6               |                   7&lt;br /&gt;
  S14              |                   1&lt;br /&gt;
  S15              |                   1&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 18 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, имеющих состояние больше 1000 и поставляющих деталь с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем средний объём поставки, выполненной поставщиками с именем &#039;Иванов&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:2nd dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Второй по сложности запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;4px&amp;quot;&amp;gt;&#039;&#039;&#039;Вот уж не свезло, так не свезло&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                       ON SPJ.nomer_postavshika = S.nomer_postavshika &lt;br /&gt;
                     WHERE S.imya = &#039;Иванов&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 19 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия красных деталей, которые входят только в изделие с названием &#039;Рама 02-03&#039; в количестве, меньшем 10 единиц в поставке.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT X.nazvanie&lt;br /&gt;
FROM spasoi_ekz.p X JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_detali = X.nomer_detali&lt;br /&gt;
WHERE X.cvet = &#039;красный&#039;&lt;br /&gt;
  AND kolichestvo &amp;lt; 10&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                                        ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                    AND X.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                              AND J.nazvanie = LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;lt; 10&lt;br /&gt;
  AND SPJ.nomer_detali NOT IN (&lt;br /&gt;
                               SELECT nomer_detali&lt;br /&gt;
                               FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                         ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                            AND J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 ----------------&lt;br /&gt;
  усиленная рама&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 20 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих только белые детали.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                            ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                  WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    AND P.cvet != &#039;белый&#039;&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;белый&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE S.nomer_postavshika NOT IN (&lt;br /&gt;
                                  SELECT nomer_postavshika&lt;br /&gt;
                                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                                            ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                               AND cvet != &#039;белый&#039;&lt;br /&gt;
                                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika NOT IN  (&lt;br /&gt;
                                 SELECT spj.nomer_postavshika&lt;br /&gt;
                                 FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                                 WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                   AND p.cvet != &#039;белый&#039;&lt;br /&gt;
                                )&lt;br /&gt;
  AND nomer_postavshika  IN (&lt;br /&gt;
                             SELECT spj.nomer_postavshika&lt;br /&gt;
                             FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                             WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                               AND p.cvet = &#039;белый&#039;&lt;br /&gt;
                            );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 -----------------&lt;br /&gt;
  Рендилл Тарли&lt;br /&gt;
  Сэмвелл Тарли&lt;br /&gt;
  Мелисса Флорент&lt;br /&gt;
  Томми Версетти&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 21 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, для которых детали поставляет только и только поставщик с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Чтобы продемонстрировать выполнение запроса наглядно, возьмём поставщика не &#039;S1&#039;, а &#039;S18&#039;, который был создан специально для этого запроса. Если оставить &#039;S1&#039;, то наглядности не получится, так как по нашей схеме БД этот поставщик не попадает под условие &amp;quot;&#039;&#039;только и только&#039;&#039;&amp;quot;, и запрос вернёт пустой результат.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM  spasoi_ekz.SPJ SPJ&lt;br /&gt;
WHERE J.nomer_izdelia = SPJ.nomer_izdelia &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; AND nomer_izdelia = SPJ.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; AND nomer_izdelia != SPJ.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кинжал&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 22 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют только детали с номером &#039;P1&#039; для изделия с именем &#039;Штуцер 01-02&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj X JOIN spasoi_ekz.j J&lt;br /&gt;
                                          ON X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE X.nomer_detali != &#039;P1&#039; &lt;br /&gt;
                    AND j.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                    AND S.nomer_postavshika = X.nomer_postavshika&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- неверный запрос - номер изделия, а не название&lt;br /&gt;
SELECT imya FROM S X&lt;br /&gt;
JOIN SPJ Y ON X.nomer_postavshika=Y.nomer_postavshika&lt;br /&gt;
WHERE X.nomer_postavshika NOT IN (&lt;br /&gt;
                  SELECT DISTINCT nomer_postavshika FROM SPJ Z&lt;br /&gt;
                  WHERE Z.nomer_izdelia != &#039;Штуцер 01-02&#039;&lt;br /&gt;
                  AND Z.nomer_detali!=&#039;P1&#039;);--&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND SPJ.nomer_detali = &#039;P1&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE SPJ.nomer_postavshika NOT IN (&lt;br /&gt;
                                    SELECT nomer_postavshika&lt;br /&gt;
                                    FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                              ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                                 AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                                                            JOIN spasoi_ekz.p P&lt;br /&gt;
                                                              ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                                 AND SPJ.nomer_detali != &#039;P1&#039;&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Иван&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 23 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют деталь с названием &#039;Винт&#039; в количестве большим 100 единиц в одной поставке и имеют состояние больше среднего по их родному городу.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Винт&#039;)&lt;br /&gt;
  AND SPJ.kolichestvo &amp;gt; 100&lt;br /&gt;
  AND S.sostoyanie &amp;gt; (&lt;br /&gt;
                      SELECT AVG(SS.sostoyanie)&lt;br /&gt;
                      FROM spasoi_ekz.s SS&lt;br /&gt;
                      WHERE SS.gorod = S.gorod&lt;br /&gt;
                     );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 24 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в одном городе.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- С этим запросом возникла неожиданная проблема - задание то ли неполное, то ли неправильное, потому что нельзя однозначно сказать, что по нему требуется сделать.&lt;br /&gt;
&lt;br /&gt;
Так что тут несколько вариантов запросов (кто как понял).&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Первый вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, kol&lt;br /&gt;
FROM spasoi_ekz.p A, (&lt;br /&gt;
                      SELECT X.gorod, SUM(kolichestvo) as kol&lt;br /&gt;
                      FROM spasoi_ekz.p X, spasoi_ekz.spj Y&lt;br /&gt;
                      WHERE Y.nomer_detali = X.nomer_detali&lt;br /&gt;
                      GROUP BY X.gorod&lt;br /&gt;
                     ) B&lt;br /&gt;
WHERE A.gorod = B.gorod;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
        nazvanie       | kol&lt;br /&gt;
 ----------------------+------&lt;br /&gt;
  подставка            |    9&lt;br /&gt;
  стойка               |    9&lt;br /&gt;
  абажур               |    9&lt;br /&gt;
  гайка                |  139&lt;br /&gt;
  ось                  |   60&lt;br /&gt;
  зубчатое колесо      |   60&lt;br /&gt;
  транзистор           |   50&lt;br /&gt;
  печатная плата       |   50&lt;br /&gt;
  диод                 |   50&lt;br /&gt;
  универсальная деталь |   13&lt;br /&gt;
  уникальная деталь    |   14&lt;br /&gt;
  болт                 | 9137&lt;br /&gt;
  рама                 |   69&lt;br /&gt;
  колесо               |   69&lt;br /&gt;
  втулка               |   69&lt;br /&gt;
  бумага               | 3122&lt;br /&gt;
  плитка               |   14&lt;br /&gt;
  орнамент             |   14&lt;br /&gt;
  уголок               |   14&lt;br /&gt;
  гайка 01-01          |   27&lt;br /&gt;
  усиленная рама       |   10&lt;br /&gt;
  винт                 | 9137&lt;br /&gt;
  труселя              |    1&lt;br /&gt;
  штуцерная деталь     |   10&lt;br /&gt;
  шуруп                |  139&lt;br /&gt;
 (25 rows)&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
и --&amp;gt;&lt;br /&gt;
В уточнение задания Григорьев сказал следующее: &amp;quot;&#039;&#039;Следует учесть, что в качестве наименования города может выступать переменная, в которую в некоторой программе должно быть занесено конкретное значение перед выполнением запроса&#039;&#039;&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
То есть, вообще говоря, задание на запрос неполное, и его можно трактовать так: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в городе &amp;lt;code&amp;gt;%НАЗВАНИЕГОРОДА%&amp;lt;/code&amp;gt;. Вот эта переменная задаётся где-то в программе, а в БД идёт запрос с уже подставленным конкретным названием. &lt;br /&gt;
&lt;br /&gt;
Этот вариант запроса составлен, например, для Лондона. &lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
WHERE gorod = &#039;Лондон&#039;&lt;br /&gt;
GROUP BY nazvanie;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie | sum&lt;br /&gt;
 ----------+-----&lt;br /&gt;
  гайка    |  71&lt;br /&gt;
  шуруп    |  68&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 25 ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих хотя бы одну белую деталь для изделия с названием &#039;Велосипед 01-04&#039; с объёмом поставки большим, чем средний объём поставки этого поставщика.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ&lt;br /&gt;
                     WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 26 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера красных деталей и количество поставок этих деталей.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY P.nomer_detali;   &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос через JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT SPJ.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY SPJ.nomer_detali;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Количество поставок с ней&lt;br /&gt;
 --------------+---------------------------&lt;br /&gt;
  P15          |                         3&lt;br /&gt;
  P22          |                         1&lt;br /&gt;
  P24          |                         1&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 27 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования городов и среднее состояние поставщиков для каждого города, поставляющих детали с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем минимальный объём поставки, выполненной поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:1st dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;7px&amp;quot;&amp;gt;&#039;&#039;&#039;Сложнейший запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Сохрани Джа, вытащить такое&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.gorod AS &amp;quot;Город&amp;quot;, AVG(S.sostoyanie) AS &amp;quot;Среднее состояние&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT MIN(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                    )&lt;br /&gt;
GROUP BY S.gorod;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    Город   |   Среднее состояние&lt;br /&gt;
 -----------+-----------------------&lt;br /&gt;
  Мытищи    |    35000.500000000000&lt;br /&gt;
  Йокогама  |  1500000.000000000000&lt;br /&gt;
  Манчестер | 2571.0000000000000000&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 28 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входит хотя бы одна красная деталь весом больше 10 граммов, поставляемая только поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ1&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ1.nomer_izdelia&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ1.nomer_detali&lt;br /&gt;
WHERE P.ves &amp;gt; 10&lt;br /&gt;
 AND P.cvet = &#039;красный&#039;&lt;br /&gt;
 AND NOT EXISTS (&lt;br /&gt;
                 SELECT SPJ2.nomer_postavshika&lt;br /&gt;
                 FROM spasoi_ekz.spj SPJ2         &lt;br /&gt;
                 WHERE SPJ2.nomer_detali = P.nomer_detali&lt;br /&gt;
	 	   AND SPJ2.nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                );                     &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 -----------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 29 ===&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, которые входят только и только в состав изделия с названием &#039;Штуцер 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.p P&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT SPJ.nomer_izdelia&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                            ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                  WHERE (&lt;br /&gt;
                         J.nazvanie != LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                     OR (&lt;br /&gt;
                         J.nazvanie = LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali != P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 ------------------&lt;br /&gt;
  штуцерная деталь&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 30 ===&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------------&lt;br /&gt;
  Оша&lt;br /&gt;
  Бран Старк&lt;br /&gt;
 (2 rows)&lt;br /&gt;
[[Категория:Структурное проектирование АСОИ (10 семестр)]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</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=3865</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=3865"/>
		<updated>2013-06-16T10:15:27Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Билет 5 */   WHERE SPJ.nomer_detali - не нужен был SPJ&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;
Странно, что ни в одном билете нет запроса с сортировкой результатов. Возможно, они буду в дополнительных заданиях.&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;
В трёх билетах в задании на запрос встречается формулировка &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;
=== Билет 1 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj SPJX&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = SPJX.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
  S2&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 2 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, поставляемых более чем одним поставщиком.&lt;br /&gt;
&lt;br /&gt;
Текст запроса, каким его дал Григорьев на лекции, впоследствии исправив его:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       SUM(kolichestvo) AS &amp;quot;Сколько штук поставляется&amp;quot;,&lt;br /&gt;
       COUNT(DISTINCT nomer_postavshika) AS &amp;quot;Сколько у неё поставщиков&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       kol AS &amp;quot;Сколько штук поставляется&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT nomer_detali,&lt;br /&gt;
             SUM(kolichestvo) AS kol,&lt;br /&gt;
             COUNT(DISTINCT nomer_postavshika)&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1&lt;br /&gt;
     ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Сколько штук поставляется | Сколько у неё поставщиков&lt;br /&gt;
 --------------+---------------------------+---------------------------&lt;br /&gt;
  P1           |                        71 |                         5&lt;br /&gt;
  P10          |                         3 |                         2&lt;br /&gt;
  P11          |                         5 |                         2&lt;br /&gt;
  P12          |                        13 |                         7&lt;br /&gt;
  P14          |                      9036 |                         4&lt;br /&gt;
  P15          |                         7 |                         3&lt;br /&gt;
  P16          |                        46 |                         3&lt;br /&gt;
  P17          |                      3122 |                         3&lt;br /&gt;
  P2           |                        68 |                         4&lt;br /&gt;
  P21          |                        27 |                         4&lt;br /&gt;
  P4           |                        10 |                         2&lt;br /&gt;
  P5           |                        16 |                         2&lt;br /&gt;
 (12 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 3 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, поставляющих детали с номером &#039;P1&#039; для какого-либо изделия в количестве (в поставке) большим, чем средний объём поставок деталей с номером &#039;P2&#039; для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT X.nomer_postavshika &lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE X.nomer_detali = &#039;P1&#039;&lt;br /&gt;
  AND X.kolichestvo &amp;gt; (&lt;br /&gt;
                       SELECT AVG(kolichestvo)&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                         AND nomer_detali = &#039;P2&#039;&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT *&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      WHERE nomer_izdelia IN(&lt;br /&gt;
                             SELECT nomer_izdelia&lt;br /&gt;
                             FROM spasoi_ekz.spj&lt;br /&gt;
                             WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                            )&lt;br /&gt;
        AND nomer_izdelia IN(&lt;br /&gt;
	                     SELECT nomer_izdelia&lt;br /&gt;
	                     FROM spasoi_ekz.spj&lt;br /&gt;
	                     WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
	                    )&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE nomer_detali = &#039;P1&#039; AND kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM (&lt;br /&gt;
       SELECT *&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       WHERE nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                             )&lt;br /&gt;
         AND nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
                             )&lt;br /&gt;
      ) B&lt;br /&gt;
 WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 4 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий, для которых детали поставляет только поставщик с номером ‘S1’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                    AND X.nomer_izdelia = nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_izdelia&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE nomer_izdelia IN(&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                      )&lt;br /&gt;
  AND nomer_izdelia NOT IN(&lt;br /&gt;
                           SELECT nomer_izdelia&lt;br /&gt;
                           FROM spasoi_ekz.spj&lt;br /&gt;
                           WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                          );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_izdelia&lt;br /&gt;
 ---------------&lt;br /&gt;
  J5&lt;br /&gt;
  J16&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 5 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &amp;quot;Болт&amp;quot; в количестве (в поставке) большим, чем средний объём всех поставок деталей с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                           ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                           ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                              AND nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika IN (&lt;br /&gt;
                            SELECT nomer_postavshika&lt;br /&gt;
                            FROM spasoi_ekz.spj&lt;br /&gt;
                            WHERE nomer_detali = (&lt;br /&gt;
                                                  SELECT nomer_detali&lt;br /&gt;
                                                  FROM spasoi_ekz.p&lt;br /&gt;
                                                  WHERE LOWER(nazvanie) = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                                                 )&lt;br /&gt;
                              AND kolichestvo &amp;gt; (&lt;br /&gt;
                                                 SELECT AVG(kolichestvo)&lt;br /&gt;
                                                 FROM spasoi_ekz.spj&lt;br /&gt;
                                                 WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                                                )&lt;br /&gt;
                           );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------&lt;br /&gt;
  Оша&lt;br /&gt;
  Иванов&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 6 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, поставляемых поставщиком, проживающим в том же городе, где изготавливаются эти детали, для изделия с названием ‘Велосипед 01/23’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01/23&#039;);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос без JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.S S, spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE S.gorod = P.gorod&lt;br /&gt;
  AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
  AND nomer_izdelia = (&lt;br /&gt;
                       SELECT nomer_izdelia&lt;br /&gt;
                       FROM spasoi_ekz.j&lt;br /&gt;
                       WHERE nazvanie = LOWER(&#039;Велосипед 01/23&#039;)&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie&lt;br /&gt;
 ----------&lt;br /&gt;
  рама&lt;br /&gt;
  колесо&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 7 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входят детали с названием &#039;Болт&#039;, поставляемых поставщиками с именем &#039;Иванов&#039;, в количестве (в поставке) большим, чем средний объём поставок для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj X&lt;br /&gt;
                     WHERE SPJ.nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j&lt;br /&gt;
WHERE nomer_izdelia IN (&lt;br /&gt;
                        SELECT nomer_izdelia&lt;br /&gt;
                        FROM (spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                                      AND imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                                                 JOIN spasoi_ekz.p P&lt;br /&gt;
                                                   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                      AND nazvanie = LOWER(&#039;Болт&#039;)) A&lt;br /&gt;
                        WHERE kolichestvo &amp;gt; (&lt;br /&gt;
                                             SELECT AVG(kolichestvo)&lt;br /&gt;
                                             FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                                       ON SPJ.nomer_izdelia = A.nomer_izdelia&lt;br /&gt;
                                            )&lt;br /&gt;
                       );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант этого же запроса, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT J.nazvanie, kolichestvo&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
        AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
        AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
        AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
        AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM spasoi_ekz.spj&lt;br /&gt;
 WHERE nomer_izdelia IN(&lt;br /&gt;
                        SELECT J.nomer_izdelia&lt;br /&gt;
                        FROM spasoi_ekz.s S, spasoi_ekz.p P, spasoi_ekz.j J, spasoi_ekz.spj SPJ&lt;br /&gt;
                        WHERE J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                          AND P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                          AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
                          AND S.imya LIKE &#039;%Иванов%&#039;&lt;br /&gt;
                          AND S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                       )&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 -------------------&lt;br /&gt;
  шкаф&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 8 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий и общее количество деталей для них, поставляемых поставщиками с именем &#039;Петров&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_izdelia AS &amp;quot;Номер изделия&amp;quot;, SUM(kolichestvo) AS &amp;quot;Количество деталей&amp;quot; &lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                             -- так как &amp;quot;поставщикАМИ&amp;quot; и возможны&lt;br /&gt;
                             -- Иван Петров и Петров Иван, то LIKE %Петров%&lt;br /&gt;
                             AND imya LIKE &#039;%Петров%&#039;&lt;br /&gt;
GROUP BY nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер изделия | Количество деталей&lt;br /&gt;
 ---------------+--------------------&lt;br /&gt;
  J4            |                101&lt;br /&gt;
  J3            |                  6&lt;br /&gt;
  J13           |                  9&lt;br /&gt;
  J15           |                 40&lt;br /&gt;
  J1            |                  3&lt;br /&gt;
  J12           |                 15&lt;br /&gt;
  J14           |                 93&lt;br /&gt;
 (7 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 9 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, которые входят только в одно изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali, kol FROM (&lt;br /&gt;
       SELECT nomer_detali, SUM(kolichestvo) AS kol, COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_izdelia) = 1&lt;br /&gt;
    ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali | sum&lt;br /&gt;
 --------------+------&lt;br /&gt;
  P10          |    3&lt;br /&gt;
  P11          |    5&lt;br /&gt;
  P12          |   13&lt;br /&gt;
  P13          |   14&lt;br /&gt;
  P17          | 3122&lt;br /&gt;
  P18          |    9&lt;br /&gt;
  P19          |    1&lt;br /&gt;
  P20          |    4&lt;br /&gt;
  P21          |   27&lt;br /&gt;
  P22          |    9&lt;br /&gt;
  P23          |  101&lt;br /&gt;
  P24          |    1&lt;br /&gt;
  P25          |    1&lt;br /&gt;
  P26          |    1&lt;br /&gt;
  P3           |   50&lt;br /&gt;
  P4           |   10&lt;br /&gt;
  P6           |   20&lt;br /&gt;
  P7           |    5&lt;br /&gt;
  P8           |   25&lt;br /&gt;
  P9           |    1&lt;br /&gt;
 (20 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 10 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих детали с названием &#039;Болт&#039; для изделия с названием &#039;Рама 02-01&#039; в количестве (в поставке) большим, чем минимальное значение поставки детали с номером &#039;P1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
			   ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			      AND J.nazvanie = LOWER(&#039;Рама 02-01&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.p P&lt;br /&gt;
			   ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
			      AND P.nazvanie = LOWER(&#039;Болт&#039;)&lt;br /&gt;
			 JOIN spasoi_ekz.s S&lt;br /&gt;
			   ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE kolichestvo &amp;gt; (&lt;br /&gt;
		     SELECT MIN(kolichestvo)&lt;br /&gt;
		     FROM spasoi_ekz.spj &lt;br /&gt;
		     WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Русе Болтон&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 11 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия городов и суммарное состояние проживающих в каждом городе поставщиков, у которых минимальный объём поставки деталей больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s S&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;
&amp;lt;!-- а этот запрос выполняет не совсем то и не правильно&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, sost&lt;br /&gt;
FROM (&lt;br /&gt;
SELECT gorod, SUM(sostoyanie) AS sost, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj, spasoi_ekz.s&lt;br /&gt;
WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
GROUP BY S.gorod HAVING SUM(SPJ.kolichestvo) &amp;gt; 1000&lt;br /&gt;
) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt; &lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    gorod   |   sum&lt;br /&gt;
 -----------+---------&lt;br /&gt;
  Прага     | 2111110&lt;br /&gt;
  Стокгольм |  888888&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 12 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей, поставляемых для какого-либо изделия поставщиком, проживающим в том же городе, где изготавливается это изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali&lt;br /&gt;
FROM spasoi_ekz.spj SPJ, spasoi_ekz.s S, spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND S.gorod = J.gorod&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali&lt;br /&gt;
 --------------&lt;br /&gt;
  P15&lt;br /&gt;
  P16&lt;br /&gt;
  P26&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 13 ===&lt;br /&gt;
&lt;br /&gt;
Написать &amp;lt;u&amp;gt;один&amp;lt;/u&amp;gt; запрос SELECT: выдать количества строк в таблице S (Поставщик) 1) с пустыми значениями и 2) непустыми значениями в столбце Состояние.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT COUNT(*) - COUNT(sostoyanie) AS &amp;quot;С пустым состоянием&amp;quot;, &lt;br /&gt;
       COUNT(sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
SELECT COUNT(Snull.*) AS &amp;quot;С пустым состоянием&amp;quot;, COUNT(Snotnull.sostoyanie) AS &amp;quot;С не пустым состоянием&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s Snull RIGHT OUTER JOIN spasoi_ekz.s Snotnull&lt;br /&gt;
                                      ON Snull.nomer_postavshika = Snotnull.nomer_postavshika&lt;br /&gt;
                                         AND Snull.sostoyanie IS NULL;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  С пустым состоянием | С не пустым состоянием&lt;br /&gt;
 ---------------------+-----------------------&lt;br /&gt;
                    2 |                    16&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 14 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют детали только и только для изделия с номером &#039;J1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&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 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;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 ----------------&lt;br /&gt;
  Томми Версетти&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 15 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования изделий, для которых детали поставляют только те поставщики, у которых состояние больше 1000000 у.е.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT j.nazvanie&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;
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 = SPJ.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Вариант этого запроса без NOT EXISTS&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000000&lt;br /&gt;
  AND SPJ.nomer_izdelia NOT IN (&lt;br /&gt;
                                SELECT nomer_izdelia&lt;br /&gt;
                                FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                                                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                WHERE sostoyanie &amp;lt; 1000000&lt;br /&gt;
                               );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
  уникальное изделие&lt;br /&gt;
  процессор&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 16 ===&lt;br /&gt;
Написать запрос SELECT: выдать цвета и для каждого цвета общее количество деталей, входящих в изделие с названием &#039;Панно 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT cvet AS &amp;quot;Цвет&amp;quot;, SUM(kolichestvo) AS &amp;quot;Деталей&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
			     AND J.nazvanie = LOWER(&#039;Панно 01-03&#039;)&lt;br /&gt;
			JOIN spasoi_ekz.P P&lt;br /&gt;
			  ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
GROUP BY cvet;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&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;, 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;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_postavshika AS &amp;quot;Номер поставщика&amp;quot;, COUNT(*) AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
WHERE (&lt;br /&gt;
       SELECT AVG(kolichestvo)&lt;br /&gt;
       FROM spasoi_ekz.spj X&lt;br /&gt;
       WHERE X.nomer_postavshika = spj.nomer_postavshika&lt;br /&gt;
       ) &amp;gt; 1000&lt;br /&gt;
GROUP BY nomer_postavshika;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nom AS &amp;quot;Номер поставщика&amp;quot;, cnt AS &amp;quot;Количество поставок&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT S.nomer_postavshika AS nom,&lt;br /&gt;
             COUNT(SPJ.nomer_postavshika) AS cnt,&lt;br /&gt;
             AVG(SPJ.kolichestvo) AS kol&lt;br /&gt;
      FROM spasoi_ekz.s S, spasoi_ekz.spj SPJ&lt;br /&gt;
      WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
      GROUP BY S.nomer_postavshika&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE kol &amp;gt; 1000;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер поставщика | Количество поставок&lt;br /&gt;
 ------------------+---------------------&lt;br /&gt;
  S13              |                   1&lt;br /&gt;
  S6               |                   7&lt;br /&gt;
  S14              |                   1&lt;br /&gt;
  S15              |                   1&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 18 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, имеющих состояние больше 1000 и поставляющих деталь с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем средний объём поставки, выполненной поставщиками с именем &#039;Иванов&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:2nd dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Второй по сложности запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;4px&amp;quot;&amp;gt;&#039;&#039;&#039;Вот уж не свезло, так не свезло&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                       ON SPJ.nomer_postavshika = S.nomer_postavshika &lt;br /&gt;
                     WHERE S.imya = &#039;Иванов&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 19 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия красных деталей, которые входят только в изделие с названием &#039;Рама 02-03&#039; в количестве, меньшем 10 единиц в поставке.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT X.nazvanie&lt;br /&gt;
FROM spasoi_ekz.p X JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_detali = X.nomer_detali&lt;br /&gt;
WHERE X.cvet = &#039;красный&#039;&lt;br /&gt;
  AND kolichestvo &amp;lt; 10&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                                        ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                    AND X.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nazvanie&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                              AND J.nazvanie = LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
WHERE kolichestvo &amp;lt; 10&lt;br /&gt;
  AND SPJ.nomer_detali NOT IN (&lt;br /&gt;
                               SELECT nomer_detali&lt;br /&gt;
                               FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                         ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                            AND J.nazvanie != LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 ----------------&lt;br /&gt;
  усиленная рама&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 20 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих только белые детали.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                            ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                  WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    AND P.cvet != &#039;белый&#039;&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;белый&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE S.nomer_postavshika NOT IN (&lt;br /&gt;
                                  SELECT nomer_postavshika&lt;br /&gt;
                                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                                                            ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                               AND cvet != &#039;белый&#039;&lt;br /&gt;
                                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;И ещё один вариант этого же запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s&lt;br /&gt;
WHERE nomer_postavshika NOT IN  (&lt;br /&gt;
                                 SELECT spj.nomer_postavshika&lt;br /&gt;
                                 FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                                 WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                   AND p.cvet != &#039;белый&#039;&lt;br /&gt;
                                )&lt;br /&gt;
  AND nomer_postavshika  IN (&lt;br /&gt;
                             SELECT spj.nomer_postavshika&lt;br /&gt;
                             FROM spasoi_ekz.spj SPJ, spasoi_ekz.p P&lt;br /&gt;
                             WHERE SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                               AND p.cvet = &#039;белый&#039;&lt;br /&gt;
                            );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       imya&lt;br /&gt;
 -----------------&lt;br /&gt;
  Рендилл Тарли&lt;br /&gt;
  Сэмвелл Тарли&lt;br /&gt;
  Мелисса Флорент&lt;br /&gt;
  Томми Версетти&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 21 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, для которых детали поставляет только и только поставщик с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Чтобы продемонстрировать выполнение запроса наглядно, возьмём поставщика не &#039;S1&#039;, а &#039;S18&#039;, который был создан специально для этого запроса. Если оставить &#039;S1&#039;, то наглядности не получится, так как по нашей схеме БД этот поставщик не попадает под условие &amp;quot;&#039;&#039;только и только&#039;&#039;&amp;quot;, и запрос вернёт пустой результат.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J, spasoi_ekz.SPJ SPJ&lt;br /&gt;
WHERE J.nomer_izdelia = SPJ.nomer_izdelia &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; 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; AND nomer_izdelia != J.nomer_izdelia&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  кинжал&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 22 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют только детали с номером &#039;P1&#039; для изделия с именем &#039;Штуцер 01-02&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT *&lt;br /&gt;
                  FROM spasoi_ekz.spj X JOIN spasoi_ekz.j J&lt;br /&gt;
                                          ON X.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                  WHERE X.nomer_detali != &#039;P1&#039; &lt;br /&gt;
                    AND j.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                    AND S.nomer_postavshika = X.nomer_postavshika&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- неверный запрос - номер изделия, а не название&lt;br /&gt;
SELECT imya FROM S X&lt;br /&gt;
JOIN SPJ Y ON X.nomer_postavshika=Y.nomer_postavshika&lt;br /&gt;
WHERE X.nomer_postavshika NOT IN (&lt;br /&gt;
                  SELECT DISTINCT nomer_postavshika FROM SPJ Z&lt;br /&gt;
                  WHERE Z.nomer_izdelia != &#039;Штуцер 01-02&#039;&lt;br /&gt;
                  AND Z.nomer_detali!=&#039;P1&#039;);--&amp;gt;&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                             AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                        JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND SPJ.nomer_detali = &#039;P1&#039;&lt;br /&gt;
                        JOIN spasoi_ekz.s S&lt;br /&gt;
                          ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
WHERE SPJ.nomer_postavshika NOT IN (&lt;br /&gt;
                                    SELECT nomer_postavshika&lt;br /&gt;
                                    FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                                              ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                                                                 AND J.nazvanie = LOWER(&#039;Штуцер 01-02&#039;)&lt;br /&gt;
                                                            JOIN spasoi_ekz.p P&lt;br /&gt;
                                                              ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                                                                 AND SPJ.nomer_detali != &#039;P1&#039;&lt;br /&gt;
                              );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Иван&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 23 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют деталь с названием &#039;Винт&#039; в количестве большим 100 единиц в одной поставке и имеют состояние больше среднего по их родному городу.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Винт&#039;)&lt;br /&gt;
  AND SPJ.kolichestvo &amp;gt; 100&lt;br /&gt;
  AND S.sostoyanie &amp;gt; (&lt;br /&gt;
                      SELECT AVG(SS.sostoyanie)&lt;br /&gt;
                      FROM spasoi_ekz.s SS&lt;br /&gt;
                      WHERE SS.gorod = S.gorod&lt;br /&gt;
                     );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 24 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в одном городе.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;!-- С этим запросом возникла неожиданная проблема - задание то ли неполное, то ли неправильное, потому что нельзя однозначно сказать, что по нему требуется сделать.&lt;br /&gt;
&lt;br /&gt;
Так что тут несколько вариантов запросов (кто как понял).&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Первый вариант запроса&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, kol&lt;br /&gt;
FROM spasoi_ekz.p A, (&lt;br /&gt;
                      SELECT X.gorod, SUM(kolichestvo) as kol&lt;br /&gt;
                      FROM spasoi_ekz.p X, spasoi_ekz.spj Y&lt;br /&gt;
                      WHERE Y.nomer_detali = X.nomer_detali&lt;br /&gt;
                      GROUP BY X.gorod&lt;br /&gt;
                     ) B&lt;br /&gt;
WHERE A.gorod = B.gorod;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
        nazvanie       | kol&lt;br /&gt;
 ----------------------+------&lt;br /&gt;
  подставка            |    9&lt;br /&gt;
  стойка               |    9&lt;br /&gt;
  абажур               |    9&lt;br /&gt;
  гайка                |  139&lt;br /&gt;
  ось                  |   60&lt;br /&gt;
  зубчатое колесо      |   60&lt;br /&gt;
  транзистор           |   50&lt;br /&gt;
  печатная плата       |   50&lt;br /&gt;
  диод                 |   50&lt;br /&gt;
  универсальная деталь |   13&lt;br /&gt;
  уникальная деталь    |   14&lt;br /&gt;
  болт                 | 9137&lt;br /&gt;
  рама                 |   69&lt;br /&gt;
  колесо               |   69&lt;br /&gt;
  втулка               |   69&lt;br /&gt;
  бумага               | 3122&lt;br /&gt;
  плитка               |   14&lt;br /&gt;
  орнамент             |   14&lt;br /&gt;
  уголок               |   14&lt;br /&gt;
  гайка 01-01          |   27&lt;br /&gt;
  усиленная рама       |   10&lt;br /&gt;
  винт                 | 9137&lt;br /&gt;
  труселя              |    1&lt;br /&gt;
  штуцерная деталь     |   10&lt;br /&gt;
  шуруп                |  139&lt;br /&gt;
 (25 rows)&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
и --&amp;gt;&lt;br /&gt;
В уточнение задания Григорьев сказал следующее: &amp;quot;&#039;&#039;Следует учесть, что в качестве наименования города может выступать переменная, в которую в некоторой программе должно быть занесено конкретное значение перед выполнением запроса&#039;&#039;&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
То есть, вообще говоря, задание на запрос неполное, и его можно трактовать так: выдать наименования деталей и общее их количество для всех наименований деталей, изготавливаемых в городе &amp;lt;code&amp;gt;%НАЗВАНИЕГОРОДА%&amp;lt;/code&amp;gt;. Вот эта переменная задаётся где-то в программе, а в БД идёт запрос с уже подставленным конкретным названием. &lt;br /&gt;
&lt;br /&gt;
Этот вариант запроса составлен, например, для Лондона. &lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie, SUM(kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
WHERE gorod = &#039;Лондон&#039;&lt;br /&gt;
GROUP BY nazvanie;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nazvanie | sum&lt;br /&gt;
 ----------+-----&lt;br /&gt;
  гайка    |  71&lt;br /&gt;
  шуруп    |  68&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 25 ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих хотя бы одну белую деталь для изделия с названием &#039;Велосипед 01-04&#039; с объёмом поставки большим, чем средний объём поставки этого поставщика.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ&lt;br /&gt;
                     WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 26 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера красных деталей и количество поставок этих деталей.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY P.nomer_detali;   &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос через JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT SPJ.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY SPJ.nomer_detali;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Количество поставок с ней&lt;br /&gt;
 --------------+---------------------------&lt;br /&gt;
  P15          |                         3&lt;br /&gt;
  P22          |                         1&lt;br /&gt;
  P24          |                         1&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 27 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования городов и среднее состояние поставщиков для каждого города, поставляющих детали с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем минимальный объём поставки, выполненной поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:1st dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;7px&amp;quot;&amp;gt;&#039;&#039;&#039;Сложнейший запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Сохрани Джа, вытащить такое&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.gorod AS &amp;quot;Город&amp;quot;, AVG(S.sostoyanie) AS &amp;quot;Среднее состояние&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT MIN(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                    )&lt;br /&gt;
GROUP BY S.gorod;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    Город   |   Среднее состояние&lt;br /&gt;
 -----------+-----------------------&lt;br /&gt;
  Мытищи    |    35000.500000000000&lt;br /&gt;
  Йокогама  |  1500000.000000000000&lt;br /&gt;
  Манчестер | 2571.0000000000000000&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 28 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входит хотя бы одна красная деталь весом больше 10 граммов, поставляемая только поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ1&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ1.nomer_izdelia&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ1.nomer_detali&lt;br /&gt;
WHERE P.ves &amp;gt; 10&lt;br /&gt;
 AND P.cvet = &#039;красный&#039;&lt;br /&gt;
 AND NOT EXISTS (&lt;br /&gt;
                 SELECT SPJ2.nomer_postavshika&lt;br /&gt;
                 FROM spasoi_ekz.spj SPJ2         &lt;br /&gt;
                 WHERE SPJ2.nomer_detali = P.nomer_detali&lt;br /&gt;
	 	   AND SPJ2.nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                );                     &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 -----------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 29 ===&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, которые входят только и только в состав изделия с названием &#039;Штуцер 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&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 NOT EXISTS (&lt;br /&gt;
                  SELECT SPJ.nomer_izdelia&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                                            ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
                  WHERE (&lt;br /&gt;
                         J.nazvanie != LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                     OR (&lt;br /&gt;
                         J.nazvanie = LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                         AND&lt;br /&gt;
                         SPJ.nomer_detali != P.nomer_detali&lt;br /&gt;
                        )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 ------------------&lt;br /&gt;
  штуцерная деталь&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 30 ===&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------------&lt;br /&gt;
  Оша&lt;br /&gt;
  Бран Старк&lt;br /&gt;
 (2 rows)&lt;br /&gt;
[[Категория:Структурное проектирование АСОИ (10 семестр)]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</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=3805</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=3805"/>
		<updated>2013-06-12T17:51:22Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Билет 28 */&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;
Странно, что ни в одном билете нет запроса с сортировкой результатов. Возможно, они буду в дополнительных заданиях.&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/MmOgbWnr5cATO отсюда].&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;
 (17 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;
 (25 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;
 (17 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;
 (55 rows)&lt;br /&gt;
&lt;br /&gt;
== Готовые запросы ==&lt;br /&gt;
&lt;br /&gt;
Если видите, что тот или иной запрос можно составить короче и рациональней - смело вносите правку.&lt;br /&gt;
&lt;br /&gt;
=== Билет 1 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj SPJX&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = SPJX.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
  S2&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 2 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, поставляемых более чем одним поставщиком.&lt;br /&gt;
&lt;br /&gt;
Текст запроса, каким его дал Григорьев на лекции, впоследствии исправив его:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       SUM(kolichestvo) AS &amp;quot;Сколько штук поставляется&amp;quot;,&lt;br /&gt;
       COUNT(DISTINCT nomer_postavshika) AS &amp;quot;Сколько у неё поставщиков&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       kol AS &amp;quot;Сколько штук поставляется&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT nomer_detali,&lt;br /&gt;
             SUM(kolichestvo) AS kol,&lt;br /&gt;
             COUNT(DISTINCT nomer_postavshika)&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1&lt;br /&gt;
     ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Сколько штук поставляется | Сколько у неё поставщиков&lt;br /&gt;
 --------------+---------------------------+---------------------------&lt;br /&gt;
  P1           |                        71 |                         5&lt;br /&gt;
  P10          |                         3 |                         2&lt;br /&gt;
  P11          |                         5 |                         2&lt;br /&gt;
  P12          |                        13 |                         7&lt;br /&gt;
  P14          |                      9036 |                         4&lt;br /&gt;
  P15          |                         7 |                         3&lt;br /&gt;
  P16          |                        46 |                         3&lt;br /&gt;
  P17          |                      3122 |                         3&lt;br /&gt;
  P2           |                        68 |                         4&lt;br /&gt;
  P21          |                        27 |                         4&lt;br /&gt;
  P4           |                        10 |                         2&lt;br /&gt;
  P5           |                        16 |                         2&lt;br /&gt;
 (12 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 3 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, поставляющих детали с номером &#039;P1&#039; для какого-либо изделия в количестве (в поставке) большим, чем средний объём поставок деталей с номером &#039;P2&#039; для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT X.nomer_postavshika &lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE X.nomer_detali = &#039;P1&#039;&lt;br /&gt;
  AND X.kolichestvo &amp;gt; (&lt;br /&gt;
                       SELECT AVG(kolichestvo)&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                         AND nomer_detali = &#039;P2&#039;&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT *&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      WHERE nomer_izdelia IN(&lt;br /&gt;
                             SELECT nomer_izdelia&lt;br /&gt;
                             FROM spasoi_ekz.spj&lt;br /&gt;
                             WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                            )&lt;br /&gt;
        AND nomer_izdelia IN(&lt;br /&gt;
	                     SELECT nomer_izdelia&lt;br /&gt;
	                     FROM spasoi_ekz.spj&lt;br /&gt;
	                     WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
	                    )&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE nomer_detali = &#039;P1&#039; AND kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM (&lt;br /&gt;
       SELECT *&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       WHERE nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                             )&lt;br /&gt;
         AND nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
                             )&lt;br /&gt;
      ) B&lt;br /&gt;
 WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 4 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий, для которых детали поставляет только поставщик с номером ‘S1’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT 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;
&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 SPJ 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;
&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 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;
&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 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 = &#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;
&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 = &#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 = &#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;
  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;
 (19 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 SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
					       ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
					          AND P.nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Русе Болтон&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 11 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия городов и суммарное состояние проживающих в каждом городе поставщиков, у которых минимальный объём поставки деталей больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s&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;!-- этот запрос выполняет не совсем то и не правильно&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, sost&lt;br /&gt;
FROM (&lt;br /&gt;
SELECT gorod, SUM(sostoyanie) AS sost, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj, spasoi_ekz.s&lt;br /&gt;
WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
GROUP BY S.gorod HAVING SUM(SPJ.kolichestvo) &amp;gt; 1000&lt;br /&gt;
) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt; &lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    gorod   |   sum&lt;br /&gt;
 -----------+---------&lt;br /&gt;
  Прага     | 2111110&lt;br /&gt;
  Стокгольм |  888888&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 12 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей, поставляемых для какого-либо изделия поставщиком, проживающим в том же городе, где изготавливается это изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali&lt;br /&gt;
FROM spasoi_ekz.spj SPJ, spasoi_ekz.s S, spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND S.gorod = J.gorod&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali&lt;br /&gt;
 --------------&lt;br /&gt;
  P15&lt;br /&gt;
  P16&lt;br /&gt;
 (2 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(nomer_postavshika) - 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 |                    15&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;
Текст запроса:&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;
WHERE nomer_izdelia = &#039;J1&#039;&lt;br /&gt;
  AND SPJ.nomer_postavshika NOT IN (&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;
                                   );&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;
=== Билет 15 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования изделий, для которых детали поставляют только те поставщики, у которых состояние больше 1000000 у.е.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.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;
&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;
Результат:&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 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;
&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;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер поставщика | Количество поставок&lt;br /&gt;
 ------------------+---------------------&lt;br /&gt;
  S13              |                   1&lt;br /&gt;
  S6               |                   7&lt;br /&gt;
  S14              |                   1&lt;br /&gt;
  S15              |                   1&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 18 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, имеющих состояние больше 1000 и поставляющих деталь с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем средний объём поставки, выполненной поставщиками с именем &#039;Иванов&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:2nd dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Второй по сложности запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;4px&amp;quot;&amp;gt;&#039;&#039;&#039;Вот уж не свезло, так не свезло&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                       ON SPJ.nomer_postavshika = S.nomer_postavshika &lt;br /&gt;
                     WHERE S.imya = &#039;Иванов&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 19 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия красных деталей, которые входят только в изделие с названием &#039;Рама 02-03&#039; в количестве, меньшем 10 единиц в поставке.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT 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;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE X.cvet = &#039;красный&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
  AND kolichestvo &amp;lt; 10&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT J.nomer_izdelia&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;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_postavshika&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 s.imya&lt;br /&gt;
From s&lt;br /&gt;
WHERE s.nomer_postavshika NOT IN 	&lt;br /&gt;
       (	SELECT spj.nomer_postavshika		&lt;br /&gt;
        From spj, p		&lt;br /&gt;
        WHERE spj.nomer_detali=p.nomer_detali		&lt;br /&gt;
              AND p.cvet!=&#039;Белый&#039;)&lt;br /&gt;
     AND s.nomer_postavshika  IN 	&lt;br /&gt;
       (	SELECT spj.nomer_postavshika		&lt;br /&gt;
         From spj, p		&lt;br /&gt;
         WHERE spj.nomer_detali=p.nomer_detali		&lt;br /&gt;
         AND p.cvet=&#039;Белый&#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;&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;
Текст запроса:&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 J, spasoi_ekz.SPJ SPJ&lt;br /&gt;
WHERE J.nomer_izdelia = SPJ.nomer_izdelia &lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_postavshika&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                    AND nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                 );&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.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
  AND SPJ.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;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  уникальное изделие&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (2 rows)&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;
&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;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;
&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;
С этим запросом возникла неожиданная проблема - задание то ли неполное, то ли неправильное, потому что нельзя однозначно сказать, что по нему требуется сделать.&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;
и&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;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;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Билет 25 ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, поставляющих хотя бы одну белую деталь для изделия с названием &#039;Велосипед 01-04&#039; с объёмом поставки большим, чем средний объём поставки этого поставщика.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 01-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ&lt;br /&gt;
                     WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 26 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера красных деталей и количество поставок этих деталей.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT P.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.p P, spasoi_ekz.spj SPJ&lt;br /&gt;
WHERE P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
  AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY P.nomer_detali;   &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос через JOIN&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT SPJ.nomer_detali AS &amp;quot;Номер детали&amp;quot;, COUNT(kolichestvo) AS &amp;quot;Количество поставок с ней&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
                          ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                             AND cvet = &#039;красный&#039;&lt;br /&gt;
GROUP BY SPJ.nomer_detali;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Количество поставок с ней&lt;br /&gt;
 --------------+---------------------------&lt;br /&gt;
  P15          |                         3&lt;br /&gt;
  P22          |                         1&lt;br /&gt;
  P24          |                         1&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 27 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования городов и среднее состояние поставщиков для каждого города, поставляющих детали с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем минимальный объём поставки, выполненной поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:1st dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;7px&amp;quot;&amp;gt;&#039;&#039;&#039;Сложнейший запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Сохрани Джа, вытащить такое&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT S.gorod AS &amp;quot;Город&amp;quot;, AVG(S.sostoyanie) AS &amp;quot;Среднее состояние&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT MIN(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj&lt;br /&gt;
                     WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
                    )&lt;br /&gt;
GROUP BY S.gorod;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    Город   |   Среднее состояние&lt;br /&gt;
 -----------+-----------------------&lt;br /&gt;
  Мытищи    |    35000.500000000000&lt;br /&gt;
  Йокогама  |  1500000.000000000000&lt;br /&gt;
  Манчестер | 2571.0000000000000000&lt;br /&gt;
 (3 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 28 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия изделий, куда входит хотя бы одна красная деталь весом больше 10 граммов, поставляемая только поставщиком с номером &#039;S1&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT J.nazvanie&lt;br /&gt;
FROM spasoi_ekz.j J JOIN spasoi_ekz.spj SPJ1&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ1.nomer_izdelia&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ1.nomer_detali&lt;br /&gt;
WHERE P.ves &amp;gt; 10&lt;br /&gt;
 AND P.cvet = &#039;красный&#039;&lt;br /&gt;
 AND NOT EXISTS (&lt;br /&gt;
                 SELECT SPJ2.nomer_postavshika&lt;br /&gt;
                 FROM spasoi_ekz.spj SPJ2         &lt;br /&gt;
                 WHERE SPJ2.nomer_detali = P.nomer_detali&lt;br /&gt;
	 	   AND SPJ2.nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                );                     &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 -----------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 29 ===&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, которые входят только и только в состав изделия с названием &#039;Штуцер 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&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 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 J.nazvanie != LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                    AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 ------------------&lt;br /&gt;
  штуцерная деталь&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 30 ===&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------------&lt;br /&gt;
  Оша&lt;br /&gt;
  Бран Старк&lt;br /&gt;
 (2 rows)&lt;br /&gt;
[[Категория:Структурное проектирование АСОИ (10 семестр)]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</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=3801</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=3801"/>
		<updated>2013-06-12T13:22:36Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Билет 20 */&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;
Странно, что ни в одном билете нет запроса с сортировкой результатов. Возможно, они буду в дополнительных заданиях.&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/MmOgbWnr5cATO отсюда].&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;
 (17 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;
 (25 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;
 (17 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;
 (55 rows)&lt;br /&gt;
&lt;br /&gt;
== Готовые запросы ==&lt;br /&gt;
&lt;br /&gt;
Если видите, что тот или иной запрос можно составить короче и рациональней - смело вносите правку.&lt;br /&gt;
&lt;br /&gt;
=== Билет 1 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM spasoi_ekz.spj SPJX&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = SPJX.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
  S2&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 2 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей и общее их количество для всех номеров деталей, поставляемых более чем одним поставщиком.&lt;br /&gt;
&lt;br /&gt;
Текст запроса, каким его дал Григорьев на лекции, впоследствии исправив его:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       SUM(kolichestvo) AS &amp;quot;Сколько штук поставляется&amp;quot;,&lt;br /&gt;
       COUNT(DISTINCT nomer_postavshika) AS &amp;quot;Сколько у неё поставщиков&amp;quot;&lt;br /&gt;
FROM spasoi_ekz.spj&lt;br /&gt;
GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Ещё вариант&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali AS &amp;quot;Номер детали&amp;quot;,&lt;br /&gt;
       kol AS &amp;quot;Сколько штук поставляется&amp;quot;&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT nomer_detali,&lt;br /&gt;
             SUM(kolichestvo) AS kol,&lt;br /&gt;
             COUNT(DISTINCT nomer_postavshika)&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      GROUP BY nomer_detali HAVING COUNT(DISTINCT nomer_postavshika) &amp;gt; 1&lt;br /&gt;
     ) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер детали | Сколько штук поставляется | Сколько у неё поставщиков&lt;br /&gt;
 --------------+---------------------------+---------------------------&lt;br /&gt;
  P1           |                        71 |                         5&lt;br /&gt;
  P10          |                         3 |                         2&lt;br /&gt;
  P11          |                         5 |                         2&lt;br /&gt;
  P12          |                        13 |                         7&lt;br /&gt;
  P14          |                      9036 |                         4&lt;br /&gt;
  P15          |                         7 |                         3&lt;br /&gt;
  P16          |                        46 |                         3&lt;br /&gt;
  P17          |                      3122 |                         3&lt;br /&gt;
  P2           |                        68 |                         4&lt;br /&gt;
  P21          |                        27 |                         4&lt;br /&gt;
  P4           |                        10 |                         2&lt;br /&gt;
  P5           |                        16 |                         2&lt;br /&gt;
 (12 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 3 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера поставщиков, поставляющих детали с номером &#039;P1&#039; для какого-либо изделия в количестве (в поставке) большим, чем средний объём поставок деталей с номером &#039;P2&#039; для этого изделия.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT X.nomer_postavshika &lt;br /&gt;
FROM spasoi_ekz.spj X&lt;br /&gt;
WHERE X.nomer_detali = &#039;P1&#039;&lt;br /&gt;
  AND X.kolichestvo &amp;gt; (&lt;br /&gt;
                       SELECT AVG(kolichestvo)&lt;br /&gt;
                       FROM spasoi_ekz.spj&lt;br /&gt;
                       WHERE nomer_izdelia = X.nomer_izdelia&lt;br /&gt;
                         AND nomer_detali = &#039;P2&#039;&lt;br /&gt;
                      );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div class=&amp;quot;toccolours mw-collapsible mw-collapsed&amp;quot;&amp;gt;&lt;br /&gt;
&#039;&#039;Этот же запрос, но длиннее и нерациональней&#039;&#039;&lt;br /&gt;
&amp;lt;div class=&amp;quot;mw-collapsible-content&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nomer_postavshika&lt;br /&gt;
FROM (&lt;br /&gt;
      SELECT *&lt;br /&gt;
      FROM spasoi_ekz.spj&lt;br /&gt;
      WHERE nomer_izdelia IN(&lt;br /&gt;
                             SELECT nomer_izdelia&lt;br /&gt;
                             FROM spasoi_ekz.spj&lt;br /&gt;
                             WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                            )&lt;br /&gt;
        AND nomer_izdelia IN(&lt;br /&gt;
	                     SELECT nomer_izdelia&lt;br /&gt;
	                     FROM spasoi_ekz.spj&lt;br /&gt;
	                     WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
	                    )&lt;br /&gt;
     ) A&lt;br /&gt;
WHERE nomer_detali = &#039;P1&#039; AND kolichestvo &amp;gt;&lt;br /&gt;
(&lt;br /&gt;
 SELECT AVG(kolichestvo)&lt;br /&gt;
 FROM (&lt;br /&gt;
       SELECT *&lt;br /&gt;
       FROM spasoi_ekz.spj&lt;br /&gt;
       WHERE nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P1&#039;&lt;br /&gt;
                             )&lt;br /&gt;
         AND nomer_izdelia IN(&lt;br /&gt;
                              SELECT nomer_izdelia&lt;br /&gt;
                              FROM spasoi_ekz.spj&lt;br /&gt;
                              WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
                             )&lt;br /&gt;
      ) B&lt;br /&gt;
 WHERE nomer_detali = &#039;P2&#039;&lt;br /&gt;
);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_postavshika&lt;br /&gt;
 -------------------&lt;br /&gt;
  S6&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 4 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера изделий, для которых детали поставляет только поставщик с номером ‘S1’.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT 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;
&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 SPJ 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;
&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 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;
&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 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 = &#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;
&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 = &#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 = &#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;
  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;
 (19 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 SPJ JOIN spasoi_ekz.p P&lt;br /&gt;
					       ON SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
					          AND P.nomer_detali = &#039;P1&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Русе Болтон&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 11 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия городов и суммарное состояние проживающих в каждом городе поставщиков, у которых минимальный объём поставки деталей больше 1000.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, SUM(sostoyanie)&lt;br /&gt;
FROM spasoi_ekz.s&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;!-- этот запрос выполняет не совсем то и не правильно&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT gorod, sost&lt;br /&gt;
FROM (&lt;br /&gt;
SELECT gorod, SUM(sostoyanie) AS sost, SUM(SPJ.kolichestvo)&lt;br /&gt;
FROM spasoi_ekz.spj, spasoi_ekz.s&lt;br /&gt;
WHERE S.nomer_postavshika = SPJ.nomer_postavshika&lt;br /&gt;
GROUP BY S.gorod HAVING SUM(SPJ.kolichestvo) &amp;gt; 1000&lt;br /&gt;
) A;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt; --&amp;gt; &lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
    gorod   |   sum&lt;br /&gt;
 -----------+---------&lt;br /&gt;
  Прага     | 2111110&lt;br /&gt;
  Стокгольм |  888888&lt;br /&gt;
 (2 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 12 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать номера деталей, поставляемых для какого-либо изделия поставщиком, проживающим в том же городе, где изготавливается это изделие.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nomer_detali&lt;br /&gt;
FROM spasoi_ekz.spj SPJ, spasoi_ekz.s S, spasoi_ekz.j J&lt;br /&gt;
WHERE SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
  AND S.gorod = J.gorod&lt;br /&gt;
  AND J.nomer_izdelia = SPJ.nomer_izdelia;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  nomer_detali&lt;br /&gt;
 --------------&lt;br /&gt;
  P15&lt;br /&gt;
  P16&lt;br /&gt;
 (2 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(nomer_postavshika) - 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 |                    15&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;
Текст запроса:&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;
WHERE nomer_izdelia = &#039;J1&#039;&lt;br /&gt;
  AND SPJ.nomer_postavshika NOT IN (&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;
                                   );&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;
=== Билет 15 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать наименования изделий, для которых детали поставляют только те поставщики, у которых состояние больше 1000000 у.е.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT nazvanie&lt;br /&gt;
FROM spasoi_ekz.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;
&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;
Результат:&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 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;
&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;
Результат:&lt;br /&gt;
&lt;br /&gt;
  Номер поставщика | Количество поставок&lt;br /&gt;
 ------------------+---------------------&lt;br /&gt;
  S13              |                   1&lt;br /&gt;
  S6               |                   7&lt;br /&gt;
  S14              |                   1&lt;br /&gt;
  S15              |                   1&lt;br /&gt;
 (4 rows)&lt;br /&gt;
&lt;br /&gt;
=== Билет 18 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, имеющих состояние больше 1000 и поставляющих деталь с названием &#039;Гайка 01-01&#039; для изделия с названием &#039;Велосипед 03-04&#039; в количестве (в поставке) большим, чем средний объём поставки, выполненной поставщиками с именем &#039;Иванов&#039;.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Файл:2nd dufficulty.png|center]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;5px&amp;quot;&amp;gt;&#039;&#039;&#039;Второй по сложности запрос экзамена!&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p align=&amp;quot;center&amp;quot;&amp;gt;&amp;lt;font size=&amp;quot;4px&amp;quot;&amp;gt;&#039;&#039;&#039;Вот уж не свезло, так не свезло&#039;&#039;&#039;&amp;lt;/font&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT imya&lt;br /&gt;
FROM spasoi_ekz.s S JOIN spasoi_ekz.spj SPJ&lt;br /&gt;
                      ON SPJ.nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE sostoyanie &amp;gt; 1000&lt;br /&gt;
  AND P.nazvanie = LOWER(&#039;Гайка 01-01&#039;)&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Велосипед 03-04&#039;)&lt;br /&gt;
  AND kolichestvo &amp;gt; (&lt;br /&gt;
                     SELECT AVG(kolichestvo)&lt;br /&gt;
                     FROM spasoi_ekz.spj SPJ JOIN spasoi_ekz.s S&lt;br /&gt;
                       ON SPJ.nomer_postavshika = S.nomer_postavshika &lt;br /&gt;
                     WHERE S.imya = &#039;Иванов&#039;&lt;br /&gt;
                    );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     imya&lt;br /&gt;
 -------------&lt;br /&gt;
  Петров Пётр&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 19 ===&lt;br /&gt;
&lt;br /&gt;
Написать запрос SELECT: выдать названия красных деталей, которые входят только в изделие с названием &#039;Рама 02-03&#039; в количестве, меньшем 10 единиц в поставке.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT 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;
                    JOIN spasoi_ekz.j J&lt;br /&gt;
                      ON J.nomer_izdelia = SPJ.nomer_izdelia&lt;br /&gt;
WHERE X.cvet = &#039;красный&#039;&lt;br /&gt;
  AND J.nazvanie = LOWER(&#039;Рама 02-03&#039;)&lt;br /&gt;
  AND kolichestvo &amp;lt; 10&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT J.nomer_izdelia&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;
                    JOIN spasoi_ekz.p P&lt;br /&gt;
                      ON P.nomer_detali = SPJ.nomer_detali&lt;br /&gt;
WHERE cvet = &#039;белый&#039;&lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_postavshika&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 s.imya&lt;br /&gt;
From s&lt;br /&gt;
WHERE s.nomer_postavshika NOT IN 	&lt;br /&gt;
       (	SELECT spj.nomer_postavshika		&lt;br /&gt;
        From spj, p		&lt;br /&gt;
        WHERE spj.nomer_detali=p.nomer_detali		&lt;br /&gt;
              AND p.cvet!=&#039;Белый&#039;)&lt;br /&gt;
     AND s.nomer_postavshika  IN 	&lt;br /&gt;
       (	SELECT spj.nomer_postavshika		&lt;br /&gt;
         From spj, p		&lt;br /&gt;
         WHERE spj.nomer_detali=p.nomer_detali		&lt;br /&gt;
         AND p.cvet=&#039;Белый&#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;&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;
Текст запроса:&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 J, spasoi_ekz.SPJ SPJ&lt;br /&gt;
WHERE J.nomer_izdelia = SPJ.nomer_izdelia &lt;br /&gt;
  AND NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_postavshika&lt;br /&gt;
                  FROM spasoi_ekz.spj&lt;br /&gt;
                  WHERE nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                    AND nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
                 );&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.spj SPJ JOIN spasoi_ekz.j J&lt;br /&gt;
                          ON SPJ.nomer_izdelia = J.nomer_izdelia&lt;br /&gt;
WHERE nomer_postavshika = &#039;S1&#039;&lt;br /&gt;
  AND SPJ.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;
       nazvanie&lt;br /&gt;
 --------------------&lt;br /&gt;
  уникальное изделие&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (2 rows)&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;
&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;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;
&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;
С этим запросом возникла неожиданная проблема - задание то ли неполное, то ли неправильное, потому что нельзя однозначно сказать, что по нему требуется сделать.&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;
и&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;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;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&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 SS.nomer_postavshika&lt;br /&gt;
                 FROM spasoi_ekz.s SS JOIN spasoi_ekz.spj SPJ2&lt;br /&gt;
                            ON SS.nomer_postavshika = SPJ2.nomer_postavshika&lt;br /&gt;
                 WHERE SPJ2.nomer_detali = P.nomer_detali&lt;br /&gt;
	 	   AND SS.nomer_postavshika != &#039;S1&#039;&lt;br /&gt;
                );                     &lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
     nazvanie&lt;br /&gt;
 -----------------&lt;br /&gt;
  кружевное бельё&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 29 ===&lt;br /&gt;
Написать запрос SELECT: выдать названия деталей, которые входят только и только в состав изделия с названием &#039;Штуцер 01-03&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT nazvanie&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 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 J.nazvanie != LOWER(&#039;Штуцер 01-03&#039;)&lt;br /&gt;
                    AND SPJ.nomer_detali = P.nomer_detali&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
      nazvanie&lt;br /&gt;
 ------------------&lt;br /&gt;
  штуцерная деталь&lt;br /&gt;
 (1 row)&lt;br /&gt;
&lt;br /&gt;
=== Билет 30 ===&lt;br /&gt;
Написать запрос SELECT: выдать имена поставщиков, которые поставляют, по крайней мере, все те детали, которые поставляет поставщик с номером &#039;S2&#039;.&lt;br /&gt;
&lt;br /&gt;
Текст запроса:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
SELECT DISTINCT imya&lt;br /&gt;
FROM spasoi_ekz.s S&lt;br /&gt;
WHERE NOT EXISTS (&lt;br /&gt;
                  SELECT nomer_detali&lt;br /&gt;
                  FROM spasoi_ekz.spj SPJY&lt;br /&gt;
                  WHERE nomer_postavshika = &#039;S2&#039;&lt;br /&gt;
                    AND NOT EXISTS (&lt;br /&gt;
                                    SELECT *&lt;br /&gt;
                                    FROM spasoi_ekz.spj&lt;br /&gt;
                                    WHERE nomer_postavshika = S.nomer_postavshika&lt;br /&gt;
                                      AND nomer_detali = SPJY.nomer_detali&lt;br /&gt;
                                   )&lt;br /&gt;
                 );&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Результат:&lt;br /&gt;
&lt;br /&gt;
  imya&lt;br /&gt;
 ------------&lt;br /&gt;
  Оша&lt;br /&gt;
  Бран Старк&lt;br /&gt;
 (2 rows)&lt;br /&gt;
[[Категория:Структурное проектирование АСОИ (10 семестр)]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9A%D1%83%D1%80%D1%81%D0%BE%D0%B2%D0%B0%D1%8F_%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=3416</id>
		<title>Курсовая по СПАСОИ (10 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9A%D1%83%D1%80%D1%81%D0%BE%D0%B2%D0%B0%D1%8F_%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=3416"/>
		<updated>2013-04-23T21:23:11Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Курсовая работа по [[:Категория:Структурное проектирование АСОИ (10 семестр) | Структурному проектированию АСОИ]].&lt;br /&gt;
&lt;br /&gt;
== Описание ==&lt;br /&gt;
&lt;br /&gt;
Имеется некая система, например процессинговый центр. Есть БД, транзакции, сервера, банкоматы. Надо промоделировать работу этой системы.&lt;br /&gt;
&lt;br /&gt;
== ПО ==&lt;br /&gt;
&lt;br /&gt;
Выполняется с помощью программного средства КСАМ (КИСП), которое писалось для работы в среде MS Windows 98. Поэтому работать с ней предстоит в виртуальной машине, образ диска (1 ГБ) которой выдадут.&lt;br /&gt;
&lt;br /&gt;
Диск создавался для виртуальной машины [http://www.microsoft.com/en-us/download/details.aspx?id=4580 Microsoft Virtual PC 2007], но работает и в [https://www.virtualbox.org/wiki/Downloads Oracle VirtualBox].&lt;br /&gt;
&lt;br /&gt;
Его также можно просто подмонтировать через &amp;lt;code&amp;gt;Управление дисками&amp;lt;/code&amp;gt; в Windows 7 (ну и в других, где это возможно). Внутри можно найти дистрибутив этого КСАМ (который, по ходу, суть есть связка &amp;lt;code&amp;gt;Persоnal Oracle 7&amp;lt;/code&amp;gt; и &amp;lt;code&amp;gt;Oracle Forms&amp;lt;/code&amp;gt;) и дампы БД.&lt;br /&gt;
&lt;br /&gt;
Запустить где-то кроме виртуальной машины не удалось. Для работы, например, в Windows 7 требует библиотеки:&lt;br /&gt;
* &amp;lt;code&amp;gt;msvcrt2x.dll&amp;lt;/code&amp;gt;;&lt;br /&gt;
* &amp;lt;code&amp;gt;oc30.dll&amp;lt;/code&amp;gt;;&lt;br /&gt;
* &amp;lt;code&amp;gt;mfcans32.dll&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Все три можно взять из &amp;lt;code&amp;gt;\WINDOWS\SYSTEM&amp;lt;/code&amp;gt; в виртуальной машине, тогда требовать перестаёт, но запускаться тоже не начинает, потому что нужна ещё база данных, которая работает с &amp;lt;code&amp;gt;Persоnal Oracle 7&amp;lt;/code&amp;gt;, который, как раз, работает только в Windows 98. Можно, правда, попробовать перетащить это всё на новые версии и запустить-таки нормально, но до этого руки, по ходу, ни у кого не дойдут.&lt;br /&gt;
&lt;br /&gt;
== Документы ==&lt;br /&gt;
&lt;br /&gt;
* [http://yadi.sk/d/8T6YvrHI2a-1W методичка по курсовой и руководство по установке пакета];&lt;br /&gt;
* [http://yadi.sk/d/jRhi6Yue2a-2g документация по КСАМ (КИСП)];&lt;br /&gt;
* [http://yadi.sk/d/5tGPNX613i2e2 дополнительные методические материалы] (в том числе тесты TPC);&lt;br /&gt;
* [http://yadi.sk/d/eL6227982a-4I переписка Григорьева с каким-то крутым чуваком из Билайна].&lt;br /&gt;
&lt;br /&gt;
== Графики ==&lt;br /&gt;
В курсовой работе в 5 разделе необходимо построить 2 графика. У меня не получилось заставить это сделать excel, а онлайн решения были немного убогими. Поэтому было решено заюзать JS-библиотеку highcharts. Библиотека позволяет сохранить график в одном из 4 форматов - для этого в правом верхнем углу нажмите на кнопку меню.  &lt;br /&gt;
&lt;br /&gt;
[http://jsbin.com/ixuhov/31 Для графика 1]&lt;br /&gt;
&lt;br /&gt;
[http://jsbin.com/ixuhov/30 Для графика 2]&lt;br /&gt;
 &lt;br /&gt;
[[Категория:10 семестр]]&lt;br /&gt;
[[Категория:Курсовые]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%A2%D0%B5%D1%85%D0%BD%D0%BE%D0%BB%D0%BE%D0%B3%D0%B8%D0%B8_%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F_(10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=3147</id>
		<title>Категория:Технологии программирования (10 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%A2%D0%B5%D1%85%D0%BD%D0%BE%D0%BB%D0%BE%D0%B3%D0%B8%D0%B8_%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F_(10_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=3147"/>
		<updated>2013-04-03T22:05:19Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Лабораторные работы */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;p&amp;gt;{{Предмет | name=Технологии программирования | prepod=[[Тарнакин А.О.]] | lections=? | seminars=нет | labs=3 | dzs=? | rks=? | signif=по желанию | what=экзамен}}&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Технологии программирования. А конкретно - [http://ru.wikipedia.org/wiki/Java Java].&lt;br /&gt;
__TOC__&lt;br /&gt;
== Лекции ==&lt;br /&gt;
&lt;br /&gt;
За явкой следить не будут. Вики-конспектов не будет, потому что лекции даются не для конспектирования. Весь материал [[#Литература | тут]].&lt;br /&gt;
&lt;br /&gt;
== Лабораторные работы ==&lt;br /&gt;
&lt;br /&gt;
Всего 3 лабораторных.&lt;br /&gt;
&lt;br /&gt;
Выполняются на языке Java. ПО для разработки можно загрузить [http://www.oracle.com/technetwork/java/javase/downloads/index.html здесь]. Необходимы &amp;lt;code&amp;gt;JRE&amp;lt;/code&amp;gt; и &amp;lt;code&amp;gt;JDK&amp;lt;/code&amp;gt;. В качестве &amp;lt;code&amp;gt;IDE&amp;lt;/code&amp;gt; вполне хватит &amp;lt;code&amp;gt;NetBeans&amp;lt;/code&amp;gt;. Сервером приложений лучше выбрать &amp;lt;code&amp;gt;Apache Tomcat&amp;lt;/code&amp;gt;, а не &amp;lt;code&amp;gt;GlassFish&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Как можно заметить, описания работ даны в очень общем виде, без подробных требований. По этому поводу прямая речь от преподавателя: &amp;lt;blockquote&amp;gt;&#039;&#039;Задания умышленно не детализирую, мне интересно посмотреть на ваше творчество.&#039;&#039;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Сдача лабораторных (и курсовой) происходит по принципу &amp;quot;чем раньше - тем проще&amp;quot;. В начале вообще по коду ничего отвечать не надо и нет дополнительных заданий. Но начиная где-то с мая сдать станет ощутимо сложнее.&lt;br /&gt;
&lt;br /&gt;
[https://github.com/zhukovRoman/Java Альтернативные версии лабораторных для разнообразия]&lt;br /&gt;
&lt;br /&gt;
=== Лабораторная работа №1 ===&lt;br /&gt;
&lt;br /&gt;
Работа с базовыми классами стандартных пакетов &amp;lt;code&amp;gt;java.io&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;java.net&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;java.util&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Задание:&lt;br /&gt;
* необходимо получить содержимое web-странички, проиндексировать слова в нём (в содержимом) и результаты сохранить в файл;&lt;br /&gt;
* программа должна быть исполнена в виде консольного приложения, позволяющего выбирать адрес web-страницы и имя файла, в который будут сохранены результаты;&lt;br /&gt;
* программу необходимо компилировать и запускать без помощи IDE (но сам код можно писать и в IDE).&lt;br /&gt;
&lt;br /&gt;
Ссылки по теме:&lt;br /&gt;
* [http://en.wikibooks.org/wiki/Java_Programming/Understanding_a_Java_Program как устроена Java-программа];&lt;br /&gt;
* [http://www.skipy.ru/technics/likbez.html#hello компиляция и запуск из консоли Windows];&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/essential/io/ основы ввода/вывода];&lt;br /&gt;
* [http://docs.oracle.com/javase/6/docs/api/java/net/package-summary.html#package_description работа с сетью];&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/collections/index.html контейнерные классы].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |+ Готовые работы&lt;br /&gt;
 ! Год !! Описание !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || сбор только русских слов через RegExp&amp;lt;br&amp;gt;Notepad++, командная строка || [http://yadi.sk/d/14F6O7jx2vpNM загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Лабораторная работа №2 ===&lt;br /&gt;
&lt;br /&gt;
Выполняется на базе ЛР №1.&lt;br /&gt;
&lt;br /&gt;
Работа с БД, многопоточность, синхронизация, журналирование.&lt;br /&gt;
&lt;br /&gt;
Задание:&lt;br /&gt;
* программа должна быть выполнена как многопоточное приложение, использующее &amp;lt;code&amp;gt;java.util.concurrent&amp;lt;/code&amp;gt; и позволяющее ограничивать загрузку процессора;&lt;br /&gt;
* индексация каждой странички должна производиться в отдельном потоке, содержимое сохранять в БД тройками вида &#039;&#039;&#039;&amp;lt;code&amp;gt;слово - частота упоминания на странице - страница&amp;lt;/code&amp;gt;&#039;&#039;&#039;. Найденные на страничке ссылки (&#039;&#039;&#039;&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;href=&amp;quot;http://...&amp;quot;&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt;&#039;&#039;&#039;) должны обрабатываться отличным от текущего потоком;&lt;br /&gt;
* программа должна выполнять поиск по словам и выводить адреса проиндексированных ранее страничек в порядке, пропорциональном частоте появления слова на страничке;&lt;br /&gt;
* программа должна писать отладочные сообщения посредством стандартных механизмов [http://ru.wikipedia.org/wiki/Slf4J SLF4J].&lt;br /&gt;
&lt;br /&gt;
Ссылки по теме:&lt;br /&gt;
* драйвера для работы с БД:&lt;br /&gt;
** [http://jdbc.postgresql.org/ PostgreSQL];&lt;br /&gt;
** [http://www.mysql.com/products/connector/ MySQL];&lt;br /&gt;
** [http://hsqldb.org/ HyperSQL];&lt;br /&gt;
* [http://en.wikipedia.org/wiki/Java_Database_Connectivity работа с БД];&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/essential/concurrency/index.html многопоточность];&lt;br /&gt;
** [http://docs.oracle.com/javase/tutorial/essential/concurrency/highlevel.html синхронизация потоков] (чтобы не писать свой велосипед);&lt;br /&gt;
* [http://www.rsdn.ru/forum/java/3622844.1 вопросы для самоконтроля].&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |+ Готовые работы&lt;br /&gt;
 ! Год !! Описание !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || СУБД PostgreSQL (схема БД есть), настройки из config.ini&amp;lt;br&amp;gt;NetBeans || [http://yadi.sk/d/IdpS3C923i3UW загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
=== Лабораторная работа №3 ===&lt;br /&gt;
&lt;br /&gt;
Выполняется на базе ЛР №2.&lt;br /&gt;
&lt;br /&gt;
Создание web-сервисов.&lt;br /&gt;
&lt;br /&gt;
Задание:&lt;br /&gt;
* программа должна быть выполнена в виде web-приложения, индексирующего в фоновом режиме содержимое страничек, и обрабатывать поисковые запросы посредством [http://ru.wikipedia.org/wiki/REST REST] web-сервиса.&lt;br /&gt;
&lt;br /&gt;
Ссылки по теме:&lt;br /&gt;
* [http://habrahabr.ru/post/38730/ архитектура REST];&lt;br /&gt;
* [http://www.devx.com/Java/Article/42873 RESTful веб-сервисы и Java];&lt;br /&gt;
* [http://docs.jboss.org/resteasy/docs/1.1.GA/userguide/html_single/index.html руководство по работе с RESTful веб-сервисами на Java] - перечислены все методы и их параметры;&lt;br /&gt;
* [http://javadev.ru/Eclipse_Web_Tools_Platform/ пример создания веб-приложения с сервлетом] - очень помогает разобраться, только не надо делать оттуда всё подряд. Всё необходимое находится в итерациях 2 и 3, где про сервлет и класс &amp;lt;code&amp;gt;Database&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://jersey.java.net/use/getting-started.html Jersey] и [http://jersey.java.net/nonav/documentation/latest/user-guide.html документация по Jersey];&lt;br /&gt;
* [http://www.blogsoncloud.com/jsp/blogs/restful-web-service-using-jersey.jsp пример создания веб-сервиса с Jersey] - используется &amp;lt;code&amp;gt;Eclipse&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://www.vogella.com/articles/REST/article.html и ещё один пример веб-службы на Jersey] - также используется &amp;lt;code&amp;gt;Eclipse&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://vichargrave.com/restful-web-service-development-with-netbeans-and-tomcat-tutorial/ ещё один пример с Jersey] - используется &amp;lt;code&amp;gt;NetBeans&amp;lt;/code&amp;gt; и &amp;lt;code&amp;gt;Tomcat&amp;lt;/code&amp;gt;;&lt;br /&gt;
* [http://forum.vingrad.ru/forum/topic-242617/kw-restful-jax--maven-jersey.html веб-сервис на Maven].&lt;br /&gt;
&lt;br /&gt;
Если решите делать на [http://ru.wikipedia.org/wiki/SOAP SOAP] - передумайте обратно. [[Тарнакин А.О. | Тарнакин]] и все правильные чуваки не одобряют.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |+ Готовые работы&lt;br /&gt;
 ! Год !! Описание !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2013 || СУБД PostgreSQL (схема БД из ЛР №2)&amp;lt;br&amp;gt;NetBeans, Apache Tomcat || [http://yadi.sk/d/aY4qsjlT2wi6I загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Курсовая работа ==&lt;br /&gt;
&lt;br /&gt;
Страница курсовой работы находится [[Курсовая по ТП (10 семестр) | здесь]].&lt;br /&gt;
&lt;br /&gt;
== Экзамен ==&lt;br /&gt;
&lt;br /&gt;
== Литература ==&lt;br /&gt;
&lt;br /&gt;
* Хорстман, Корнел - &amp;quot;Java 2&amp;quot;;&lt;br /&gt;
* [http://en.wikibooks.org/wiki/Subject:Java_programming_language Википедия].&lt;br /&gt;
&lt;br /&gt;
[[Категория:10 семестр]]&lt;br /&gt;
[[Категория:Предметы]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%90%D0%BA%D1%81%D1%91%D0%BD%D0%BE%D0%B2_%D0%90.%D0%9D.&amp;diff=2492</id>
		<title>Аксёнов А.Н.</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%90%D0%BA%D1%81%D1%91%D0%BD%D0%BE%D0%B2_%D0%90.%D0%9D.&amp;diff=2492"/>
		<updated>2013-01-12T13:34:04Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: Новая страница: «он няяяшка»&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;он няяяшка&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%9F%D1%80%D0%BE%D0%B5%D0%BA%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5_%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%BD%D1%8B%D1%85_%D1%81%D0%B8%D1%81%D1%82%D0%B5%D0%BC_(9_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=2008</id>
		<title>Категория:Проектирование программных систем (9 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%9F%D1%80%D0%BE%D0%B5%D0%BA%D1%82%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B5_%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%BD%D1%8B%D1%85_%D1%81%D0%B8%D1%81%D1%82%D0%B5%D0%BC_(9_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=2008"/>
		<updated>2012-11-13T20:49:12Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Домашнее задание */ Добавил про редакторы UML&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;p&amp;gt;{{Предмет | name=Проектирование программных систем | prepod=[[Балдин А.В.]] | lections=? | seminars=нет |  labs=нет | dzs=1 | rks=нет | signif=желательно | what=экзамен}}&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Язык {{Википедия|UML|UML}}, а также как собрать команду разработчиков и сделать вместе с ними большой проект.&lt;br /&gt;
&lt;br /&gt;
На лекции ходить не обязательно, никого не отмечают, но желательно, иначе будет сложно въезжать в UML.&lt;br /&gt;
&lt;br /&gt;
== Домашнее задание ==&lt;br /&gt;
&lt;br /&gt;
Описать программный проект, любой. Требования: минимум 6 диаграмм на UML и полстраницы описания проекта.&lt;br /&gt;
&lt;br /&gt;
Сдавать или на лекции, или в 369 аудиторию, специальному человеку на входе.&lt;br /&gt;
&lt;br /&gt;
UML диаграммы можно создавать во множестве программ : [http://ru.wikipedia.org/wiki/%D0%98%D0%BD%D1%81%D1%82%D1%80%D1%83%D0%BC%D0%B5%D0%BD%D1%82%D1%8B_UML-%D0%BC%D0%BE%D0%B4%D0%B5%D0%BB%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F список].&lt;br /&gt;
&lt;br /&gt;
Многие из них преобразуют некий код в диаграмму. Походу считается самое тру! Есть даже  [http://www.codeuml.com/ онлайн редакторы] которые делают из &lt;br /&gt;
    Actor A&lt;br /&gt;
    participant B&lt;br /&gt;
        A -&amp;gt; B: Do Something&lt;br /&gt;
        activate B&lt;br /&gt;
        B -&amp;gt; B: Do work&lt;br /&gt;
        activate B #FFBBBB&lt;br /&gt;
        deactivate B&lt;br /&gt;
       alt Success&lt;br /&gt;
          B -&amp;gt;&amp;gt; C: Success&lt;br /&gt;
       else failed&lt;br /&gt;
        B -&amp;gt;&amp;gt; C: Fail&lt;br /&gt;
      end&lt;br /&gt;
       B --&amp;gt; A: Return&lt;br /&gt;
    deactivate B&lt;br /&gt;
&lt;br /&gt;
делают картинку. &lt;br /&gt;
&lt;br /&gt;
Если не хотите париться с выбором редактора - enterprise architect&lt;br /&gt;
&lt;br /&gt;
[http://yadi.sk/d/EaWTtrql0d2s5 сама прога]&lt;br /&gt;
&lt;br /&gt;
Генератор ключей к ней выкладывать не буду - мало ли. Всегда можно скачать [http://nnm-club.ru/forum/viewtopic.php?t=236453 тут] &lt;br /&gt;
&lt;br /&gt;
Прога немного сложная но может все, что связано с UML.&lt;br /&gt;
&lt;br /&gt;
== Экзамен ==&lt;br /&gt;
&lt;br /&gt;
== Литература ==&lt;br /&gt;
&lt;br /&gt;
* Буч Г. - &amp;quot;Объектно-ориентированный анализ и проектирование с примерами приложений на C++&amp;quot;;&lt;br /&gt;
* Буч Г., Рамбо Д., Джекобсон А. - &amp;quot;UML. Руководство пользователя&amp;quot;;&lt;br /&gt;
* Леоненков А. - &amp;quot;Самоучитель UML&amp;quot;;&lt;br /&gt;
* Орлов С.А. - &amp;quot;Технология разработки программного обеспечения&amp;quot;;&lt;br /&gt;
* Фокс Д. - &amp;quot;Программное обеспечение и его разработка&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
[[Категория:9 семестр]]&lt;br /&gt;
[[Категория:Предметы]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
	<entry>
		<id>https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%9F%D0%BE%D1%81%D1%82%D1%80%D0%B5%D0%BB%D1%8F%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B5_%D0%B1%D0%B0%D0%B7%D1%8B_%D0%B4%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_(9_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=2007</id>
		<title>Категория:Постреляционные базы данных (9 семестр)</title>
		<link rel="alternate" type="text/html" href="https://iu5bmstu.ru/index.php?title=%D0%9A%D0%B0%D1%82%D0%B5%D0%B3%D0%BE%D1%80%D0%B8%D1%8F:%D0%9F%D0%BE%D1%81%D1%82%D1%80%D0%B5%D0%BB%D1%8F%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B5_%D0%B1%D0%B0%D0%B7%D1%8B_%D0%B4%D0%B0%D0%BD%D0%BD%D1%8B%D1%85_(9_%D1%81%D0%B5%D0%BC%D0%B5%D1%81%D1%82%D1%80)&amp;diff=2007"/>
		<updated>2012-11-13T20:28:11Z</updated>

		<summary type="html">&lt;p&gt;195.19.36.135: /* Лабораторные работы */  Дополнения по первой лабе&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;p&amp;gt;{{Предмет | name=Постреляционные базы данных | prepod=[[Виноградова М.В.]] | lections=? | seminars=нет |  labs=4 | dzs=1 | rks=2 | signif=по желанию | what=зачёт}}&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Магистры проходят этот курс через год, потому они могут либо проходить его через год, либо сейчас, на пятом курсе.&lt;br /&gt;
&lt;br /&gt;
== Домашнее задание ==&lt;br /&gt;
&lt;br /&gt;
Методичку по ДЗ можно взять [http://iu5.bmstu.ru/ebook/dz.zip здесь].&lt;br /&gt;
&lt;br /&gt;
Задания и варианты по годам:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 ! Год !! Ссылка&lt;br /&gt;
 |- align=&amp;quot;center&amp;quot;&lt;br /&gt;
 | 2012 || [http://yadi.sk/d/js6KNXiw0UMPp загрузить]&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Лабораторные работы ==&lt;br /&gt;
&lt;br /&gt;
Четыре лабораторных по две пары каждая (ага, по 2 пары каждая!).&lt;br /&gt;
&lt;br /&gt;
СУБД Caché ({{Википедия|Caché|произносится именно с ударением на последний слог}}), взять можно [http://www.intersystems.ru/cache/devcorner/index.html тут].&lt;br /&gt;
&amp;lt;!--- А также [http://dev.mysql.com/downloads/ MySQL] (при установке отметить пункт &#039;&#039;Аналитический сервер&#039;&#039;). ---&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Методички:&lt;br /&gt;
* [http://iu5.bmstu.ru/ebook/lab.zip по работе с Cashe];&lt;br /&gt;
* [http://yadi.sk/d/2bPGTZ1Z0PrSn лабораторная №1];&lt;br /&gt;
* [http://yadi.sk/d/MI0ftZAl0iXXv Примерный отчет по лабе №1];&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;&#039;Список любимых вопросов по первой лабе:&#039;&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
1. Что такое глобал? где их можно посмотреть? почему первый элемент пустой?&lt;br /&gt;
&lt;br /&gt;
2. Как хранятся производные классы? Записи добавляются в какую таблицу (родителя или наследника)? Как хранится глобал производных объектов?&lt;br /&gt;
&lt;br /&gt;
3. Как передавать параметры в SQL-запрос? Как их оттуда забирать?&lt;br /&gt;
&lt;br /&gt;
4. Спрашивает почему вызывается метод одного класса а не другого при наследовании.&lt;br /&gt;
&lt;br /&gt;
&#039;&#039;Пример: метод Inf() d классе курсы и иностранные курсы. Выбираем объект класса курсы, но который может быть приведен к производному. Вызывается метод Inf() производного. вопрос: почему? ответ: полиморфизм!&#039;&#039;&lt;br /&gt;
&lt;br /&gt;
5. Как проверить существование объекта через терминал ( это про .%ExistsId())&lt;br /&gt;
&lt;br /&gt;
6. В чем отличие метода класса от метода экземпляра класса&lt;br /&gt;
&lt;br /&gt;
7. Как выполняется sql из каше? &lt;br /&gt;
&lt;br /&gt;
    set o=##class(%ResultSet).%New(&amp;quot;%DynamicQuery:SQL&amp;quot;)&lt;br /&gt;
    do o.Prepare(&amp;quot;select * from Lesson where ofcour-&amp;gt;name =&#039;&amp;quot;_lang_&amp;quot;&#039;&amp;quot;)&lt;br /&gt;
    do o.Execute()&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
нужно рассказать про каждую строчку что она делает.&lt;br /&gt;
&lt;br /&gt;
8. Как хранятся массивы? Какой формат у ID элемента массива. &lt;br /&gt;
&lt;br /&gt;
9. .... &lt;br /&gt;
&lt;br /&gt;
* [http://yadi.sk/d/0u0rlgYT0PrUp лабораторная №2] (пока только для 1 и 2 группы, можно брать их варианты).&lt;br /&gt;
&lt;br /&gt;
== РК ==&lt;br /&gt;
&lt;br /&gt;
Два РК. Оба &amp;lt;strike&amp;gt;не обязательные, можно не писать&amp;lt;/strike&amp;gt; обязательные, без них не будет зачёта. Если написать хорошо и вовремя, то можно претендовать на зачёт автоматом.&lt;br /&gt;
&lt;br /&gt;
=== РК 1 ===&lt;br /&gt;
&lt;br /&gt;
Билет РК состоит из трёх практических упражнений.&lt;br /&gt;
&lt;br /&gt;
* [http://yadi.sk/d/u12OqHhqr_da примеры заданий на РК].&lt;br /&gt;
&lt;br /&gt;
=== РК 2 ===&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;Базы данных, языки и модели&amp;quot;;&lt;br /&gt;
* Гарсиа, Малина, Ульман, Уидоу - &amp;quot;Схемы БД&amp;quot;;&lt;br /&gt;
* Кирстеп - &amp;quot;Cashe&amp;quot;;&lt;br /&gt;
* [http://citforum.ru/database/ http://citforum.ru/database/]&lt;br /&gt;
&lt;br /&gt;
[[Категория:9 семестр]]&lt;br /&gt;
[[Категория:Предметы]]&lt;/div&gt;</summary>
		<author><name>195.19.36.135</name></author>
	</entry>
</feed>