Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Подготовка к ПР_2.1.docx
Скачиваний:
0
Добавлен:
01.05.2025
Размер:
1.4 Mб
Скачать

2.1. Оператор where

Условия поиска в операторе where (где) являются логическими выражениями, т. е. принимающими одно из двух возможных зна­чений — true (ИСТИНА) или false (ЛОЖЬ). Например, выра­жение Сумма__заказа > 500 является истинным (имеет значение true), если в текущей записи таблицы значение столбца Сумма_заказа превышает 500. В противном случае это выражение ложно (имеет значение false). Одно и то же логическое выраже­ние может быть истинным для одних записей и ложным для дру­гих. Вообще говоря, в SQL логические выражения могут принимать еще и неопределенное значение. Это происходит тогда, ко­гда в выражении некоторые элементы имеют значение null. Та­ким образом, в SQL мы имеем дело не с классической двузнач­ной, а с трехзначной логикой.

Таким образом, выражение, следующее за оператором where, воз­вращает одно из трех значений: true, false или null. При вы­полнении запроса (SQL-выражения) логическое выражение where применяется ко всем записям исходной таблицы. Если оно ис­тинно для данной записи исходной таблицы, то эта запись вы­бирается и будет представлена в результатной таблице; в против­ном случае запись не попадет в результатную таблицу.

При составлении логических выражений используются спе­циальные ключевые слова и символы операций сравнения, которые называют предикатами. Например, в выражении Сумма_заказа > 500 применен предикат сравнения (>).

Выражения с оператором where используются не только при вы­борке данных (т. е. с оператором select), но и при вставке, мо­дификации и удалении записей.

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

Далее при­веден список всех предикатов:

Предикаты сравнения:

  • (=), (<), (>), (<>), (<=), (>=);

  • BETWEEN;

  • IN, NOT IN;

  • LIKE, NOT LIKE;

  • IS NULL;

Предикаты для вложенных запросов:

  • ALL, SOME, ANY;

  • EXISTS;

  • UNIQUE;

  • DISTINCT;

  • OVERLAPS;

  • MATCH;

  • SIMILAR.

Предикаты сравнения

В первую очередь это операторы сравнения: (=), (<), (>), (<>), (<=), (>=).

BETWEEN

Предикат between (между) позволяет задать выражение проверки вхождения какого-либо значения в диапазон, определяемый гра­ничными значениями. Например:

WHERE Сумма_заказа BETWEEN 100 AND 750

Здесь ключевое слово and представляет собой логический союз И. Граничные значения (в примере это 100 и 750) входят в диапа­зон. Причем первое граничное значение должно быть не больше второго.

Эквивалентным приведенному является выражение с предиката­ми сравнения:

WHERE Сумма_заказа >= 100 AND Сумма_заказа <= 750

Кроме данных числового типа, в выражениях с beetween можно использовать данные следующих типов: символьные, битовые, даты-времени. Так например, чтобы выбрать записи, в которых имена клиентов находятся в диапазоне от А до Ж, можно исполь­зовать такое выражение:

SELECT Имя, Адрес FROM Клиенты

WHERE Имя BETWEEN 'A' AND 'Ж';

IN и NOT IN

Предикаты in (в) и not in (не в) применяются для проверки вхождения какого-либо значения в заданный список значений. Например, для выборки записей о клиентах из некоторых регио­нов можно использовать такое выражение:

SELECT Имя, Адрес FROM Клиенты

WHERE Регион IN ('Северо-запад', 'Ставропольский край', 'Иркутская область');

Если требуется получить данные о всех клиентах не из Москвы и Северо-Запада, то можно использовать предикат not in:

SELECT Имя, Адрес FROM Клиенты

WHERE Регион NOT IN ('Москва', 'Санкт-Петербург');

LIKE и NOT LIKE

Предикаты like (похожий) и not like (не похожий) применяют­ся для проверки частичного соответствия символьных строк. На­пример, столбец телефон в некоторой таблице содержит полные номера телефонов, а вам требуется выбрать лишь те записи, в которых номера телефонов начинаются с 348 или содержат та­кое сочетание цифр.

Критерий частичного соответствия задается с помощью двух символов-масок: знака процента (%) и подчеркивания (_). Знак процента означает любой набор символов, в том числе и пустой, а символ подчеркивания — любой одиночный символ.

Например, чтобы выбрать записи о клиентах, у которых номера телефонов начинаются с 348, можно использовать такое выра­жение:

SELECT Имя, Адрес, Телефон FROM Клиенты

WHERE Телефон LIKE '348%';

Допустим, столбец Адрес содержит полный почтовый адрес (ин­декс, название города, улицы и т. д.). Если вам требуется выбрать записи о клиентах, проживающих в Санкт-Петербурге, то для этого подойдет следующее выражение:

SELECT Имя, Адрес, Телефон FROM Клиенты

WHERE Адрес LIKE '%Санкт-Петербург%';

Если вы хотите исключить всех клиентов, проживающих в Моск­ве, то воспользуйтесь таким выражением:

SELECT Имя, Адрес, Телефон FROM Клиенты

WHERE Адрес NOT LIKE '%Москва%';

Возможно, вам потребуется выбрать записи, содержащие симво­лы процента и/или подчеркивания. Тогда необходимо, чтобы такие символы воспринимались интерпретатором SQL не как символы-маски. Чтобы знак процента или подчеркивания вос­принимался буквально, перед ним необходимо указать специаль­ный управляющий символ. Этот символ можно определить про­извольно, лишь бы он не встречался в качестве элемента данных. В следующем примере показано, как это можно сделать:

SELECT Имя, Адрес, Процент_скидки FROM Клиенты

WHERE Процент_скидки LIKE '20#%' ESCAPE '# ' ;

Здесь за ключевым словом escape указывается символ, который используется в качестве управляющего. Таким же способом можно отключить и сам управляющий символ.

IS NULL

Предикат IS NULL применяется для выявления записей, в кото­рых тот или иной столбец не имеет значения. Например, для по­лучения записей о клиентах, для которых не указан адрес, можно использовать следующее выражение:

SELECT Имя, Адрес, Регион FROM Клиенты

WHERE Адрес IS NULL;

Для получения записей, в которых столбец Адрес содержит неко­торые определенные значения (т. е. отличные от null), можно использовать аналогичное выражение, но с логическим операто­ром not (не):

SELECT Имя, Адрес, Регион FROM Клиенты

WHERE Адрес IS NOT NULL;

Не следует использовать предикаты сравнения с null, такие как Адрес = NULL.