Следующий оператор проверяет, находится ли первый операнд за пределами промежутка между вторым и третьим операндом.
Оператор x NOT BETWEEN a AND b
Оператор возвращает результат, противоположный результату оператора «между»:
• 1 (TRUE) – если х меньше a или больше b;
• 0 (FALSE) – если a < х < b:
• NULL – в остальных случаях.
Например, запрос
SELECT * FROM Customers WHERE name NOT BETWEEN \'КРЫЛОВ\' AND \'ООО «Кускус»;
возвращает следующие строки таблицы Customers (Клиенты) (табл. 3.12). Таблица 3.12.Результат выполнения запроса
Следующий оператор проверяет наличие первого операнда в списке значений, который является вторым операндом.
Оператор x IN (<���Список значений>)
Оператор «содержится в списке» возвращает следующие значения:
• 1 (TRUE) – если х совпадает с одним из элементов списка;
• 0 (FALSE) – если х не совпадает ни с одним из элементов списка;
• NULL – если х равен NULL, а также в тех случаях, когда в списке присутствует значение NULL и при этом х не совпадает ни с одним из элементов списка.
Например, запрос
SELECT * FROM Customers WHERE rating IN (500,1500,2500);
возвращает результат, представленный в табл. 3.12.
Оператор IN позволяет также сравнивать составные значения, то есть значение х и элементы списка могут представлять собой наборы из нескольких величин (количество компонентов во всех наборах должно быть одинаковым).
Например, запрос
SELECT * FROM Orders WHERE (date,product_id) IN
((\'2007-12-12\',1),(\'2007-12-12\',2),
(\'2007-12-13\',1),(\'2007-12-13\',2));
сравнивает каждую пару, состоящую из даты заказа (date) и номера товара (customer_id), со списком пар, и если оба компонента в паре совпадают с соответствующими компонентами какой-либо пары из списка, то строка таблицы Orders (Заказы) будет включена в результат запроса. Таким образом, запрос отбирает заказы товаров № 1 и № 2, сделанные 12 и 13 декабря 2007 г. (табл. 3.13). Таблица 3.13.Результат выполнения запроса
В отличие от функций LEAST, GREATEST, INTERVAL и COALESCE, списком значений для оператора IN может быть не только фиксированный перечень аргументов, но и результат подзапроса (соответствующий пример мы рассматривали в подразделе «Вложенные запросы» главы 2).
Следующий оператор проверяет отсутствие первого операнда в списке значений, который является вторым операндом.
Оператор x NOT IN (<���Список значений>)
Оператор «не содержится в списке» возвращает результат, противоположный результату оператора IN:
• 1 (TRUE), если х не совпадает ни с одним из элементов списка;
• 0 (FALSE) – если х совпадает с одним из элементов списка;
• NULL, если х равен NULL, а также в тех случаях, когда в списке присутствует значение NULL и при этом х не совпадает ни с одним из элементов списка.
Например, запрос
SELECT * FROM Customers WHERE rating NOT IN (500,1500);
возвращает результат, представленный в табл. 3.11.
Этот оператор, как и оператор IN, может работать с составными значениями, а также со списком, полученным в результате подзапроса.
Следующий оператор проверяет соответствие первого операнда шаблону, который является вторым операндом.
Оператор x LIKE y
Оператор сравнения с шаблоном возвращает следующие значения:
• 1 (TRUE) – если х соответствует шаблону у;
• 0 (FALSE) – если х не соответствует шаблону у;
• NULL – если х или у равен NULL.
В шаблоне можно использовать два специальных подстановочных символа:
• % – на месте знака процента может быть любое количество произвольных символов операнда х;
• _ – на месте знака подчеркивания может быть ровно один произвольный символ операнда х.
Например, следующий запрос выводит данные о тех клиентах, чьи имена содержат кавычки:
SELECT * FROM Customers WHERE name LIKE \'%\'\'%\'\'%\
Результат этого запроса представлен в табл. 3.14. Таблица 3.14.Результат выполнения запроса
Если требуется включить в шаблон знак процента или подчеркивания, которые должны рассматриваться не как подстановочные, а как обычные символы, перед ними нужно поставить обратную косую черту («\%», «\_»). Если же шаблон должен содержать символ обратной косой черты, то ее нужно удвоить («\\»). Например, значение выражения \_% LIKE \\\_\% истинное.
По умолчанию сравнение с помощью оператора LIKE выполняется без учета регистра символов (то есть заглавная и строчная буквы рассматриваются как одинаковые). Для сравнения с учетом регистра (чтобы заглавная и строчная буквы рассматривались как разные) необходимо указать ключевое слово BINARY или правило сравнения (COLLATE). Например, выражение \'Крылов\' LIKE \'крылов\' истинно, а выражения \'Крылов\' LIKE BINARY \'крылов\' и \'Крылов\' LIKE \'крылов\' COLLATE utf8_bin ложны (правило сравнения должно соответствовать кодировке, в которой работает ваше клиентское приложение; правила сравнения мы рассмотрели в разделе «Создание базы данных» главы 2).
...
Читать дальше
Конец ознакомительного отрывка
Купить книгу