Продвижение сайта по поисковым запросам, контекстная реклама, качественный копирайтинг и рерайтинг, создание сайта под ключ, QA процедуры и аудит в ИТ, бизнес анализ в Киеве, Украина.

Поиск

Админ

Как работает EXISTS sql


Как работает EXISTS sql

EXISTS — это оператор, который производит верное или неверное значение, другими словами, выражение Буля (см. Главу 4 для обзора этого термина). Это означает, что он может работать автономно в предикате или в комбинации с другими выражениями Буля, использующими Булевы операторы AND, OR, и NOT. Он берет подзапрос как аргумент и оценивает его как верный, если тот производит любой вывод, или как неверный, если тот не делает этого. Этим он отличается от других операторов предиката, в которых он не может быть неизвестным. Например, мы можем решить, извлекать ли нам некоторые данные из таблицы Заказчиков, если, и только если, один или более заказчиков в этой таблице находятся в San Jose (вывод для этого запроса показывается в Рисунке 12.1):

SELECT cnum, cname, city
FROM Customers
WHERE EXISTS (SELECT *
FROM Customers
WHERE city = 'San Jose');

===============  SQL execution Log ============
| SELECT snum, sname, city                      |
| FROM  Customers                               |
| WHERE EXISTS                                  |
| (SELECT *                                     |
| FROM Customers                                |
| WHERE city = 'San Jose');                     |
| ============================================= |
|   cnum     cname     city                     |
|  -----    --------   ----                     |
|   2001    Hoffman    London                   |
|   2002    Giovanni   Rome                     |
|   2003    Liu        San Jose                 |
|   2004    Grass      Berlin                   |
|   2006    Clemens    London                   |
|   2008    Cisneros   San Jose                 |
|   2007    Pereira    Rome                     |
===============================================

Рисунок 12.1. Использование оператора EXISTS.

Внутренний запрос выбирает все данные для всех заказчиков в San Jose. Оператор EXISTS во внешнем предикате отмечает, что некоторый вывод был произведен подзапросом, и поскольку выражение EXISTS было полным предикатом, делает предикат верным. Подзапрос (не соотнесенный) был выполнен только один раз для всего внешнего запроса, и, следовательно, имеет одно значение во всех случаях. Поэтому EXISTS, когда используется этим способом, делает предикат верным или неверным для всех строк сразу, что это не так уж полезно для извлечения определенной информации.

Выбор столбцов с помощью EXISTS

В вышеупомянутом примере, EXISTS должен быть установлен так, чтобы легко выбрать один столбец, вместо того, чтобы выбирать все столбцы, используя в выборе звезду (SELECT *). В этом состоит его отличие от подзапроса, который (как вы видели ранее в Главе 10) мог выбрать только один столбец.

Однако, в принципе он мало отличается при выборе EXISTS столбцов, или когда выбираются все столбцы, потому что он просто замечает, выполняется или нет вывод из подзапроса, а не использует выведенные значения.

Популярность: 8%




Оставить комментарий или два


Навигация

Блог / Главная / Разработка / Как работает EXISTS sql

Инфо

Запись опубликовал admin 27 апреля 2010 года и разместил в рубрике Разработка.   Запись имеет метки:   К статье пока нет комментариев. Вы можете быть первым.  

Случайные записи

Выбор ключевых слов для сайта Внешний ключ и родительский ключ sql Условия и терминология SQL Приобретение брандмауэра