Использование оператора EXISTS
Используемый в SQL оператор EXISTS (существует) гене рирует значение истина или ложь, подобно булеву выражению Используя подзапросы в качестве аргумента, этот операто оценивает результат выполнения подзапроса как истинный если этот подзапрос генерирует выходные данные, то ест в случае существования (возврата) хотя бы одного найденного значения. В противном случае результат подзапроса ложный Оператор EXISTS не может принимать значение UNKNOWN (не известно).
Пусть, например, нужно извлечь из таблицы EXAM_MARK данные о студентах, получивших хотя бы одну неудовлетвори тельную оценку.
SELECT DISTINCT STUDENT_ID FROM EXAM_MARKS A WHERE EXISTS (SELECT *
FROM EXAM_MARKS В
WHERE MARK < 3
AND B.STUDENT_ID = A. STUDENT_ID) ;
При использовании связанных подзапросов предложение EXISTS анализирует каждую строку таблицы, на которую имеется ссылка во внешнем запросе. Главный запрос получает строки-кандидаты на проверку условия. Для каждой строки-кандидата выполняется подзапрос. Как только подзапрос находит строку, где в столбце MARK значение удовлетворяет условию, он прекращает выполнение и возвращает значение истина внешнему запросу, который затем анализирует свою строку-кандидата. Например, требуется получить идентификаторы предметов обучения, экзамены по которым сдавались не одним, а несколькими студентами:
SELECT DISTINCT SUBJ_ID
FROM EXAM_MARKS A WHERE EXISTS (SELECT * FROM EXAM_MARKS В
WHERE A.SUBJ ID = B.SUBJ_ID
AND A.STUDENT_ID < > В.STUDENT_ID);
Часто EXISTS применяется с оператором NOT (по-русски NOT EXISTS интерпретируется, как «не существует»). Если предыдущий запрос сформулировать следующим образом — найти идентификаторы предметов обучения, которые сдавались одним, и только одним студентом (другими словами, для которых не существует другого сдававшего студента), то достаточно просто поставить NOT перед EXISTS.
Следует иметь в виду, что в подзапросе, указываемом в операторе EXISTS, нельзя использовать агрегирующие функции.
Возможности применения вложенных запросов весьма разнообразны. Например, пусть из таблицы STUDENT требуется извлечь строки для каждого студента, сдавшего более одного I предмета.
SELECT *
FROM STUDENT FIRST WHERE EXISTS
(SELECT SUBJ_ID
FROM EXAM_MARKS SECOND
GROUP BY SUBJ_ID
HAVING COUNT (SUBJ_IDj > 1
WHERE FIRST. STUDENT ID = SECOND. STUDENT ID);
Упражнения
Напишите запрос с EXISTS, позволяющий вывести данные обо всех студентах, обучающихся в вузах, которые имеют рейтинг выше 300
Напишите предыдущий запрос, используя соединения. Напишите запрос с EXISTS, выбирающий сведения обо всех студентах, для которых в том же городе, где живет студент, существуют университеты, в которых он не учится.
Напишите запрос, выбирающий из таблицы SUBJECT данные о названиях предметов обучения, экзамены по которым сданы более чем одним студентом.
| Maya 3D графика в кино и телевидении Воздействие испытаний ядерного оружия на здоровье населения Объектно-ориентированный язык программирования Java Объектно-ориентированное программирование Delphi Библиотека визуальных компонентов VCL и ее базовые классы Кроссплатформенное программирование для Linux Элементы управления Win32 Элементы управления Windows XP Файлы и устройства ввода/вывода Что такое экспертная система? Объектно-ориентированное программирование Инструментальные средства разработки экспертных систем Программирование на языке CLIPS Критерии и количественные характеристики надежности Расчет характеристик надежности невостанавливаемых резервированных изделий Расчет надежности системы с постоянным резервированием Интегрирование тригонометрических функций ; |