xlink:href='#Autogen_eBook_id70'/>
Следующий оператор проверяет, находится ли первый операнд за пределами промежутка между вторым и третьим операндом.
Оператор x NOT BETWEEN a AND bОператор возвращает результат, противоположный результату оператора «между»:
• 1 (TRUE) – если х меньше
• 0 (FALSE) – если
• NULL – в остальных случаях.
Например, запросвозвращает следующие строки таблицы Customers (Клиенты) (табл. 3.12). Таблица 3.12. Результат выполнения запроса
Следующий оператор проверяет наличие первого операнда в списке значений, который является вторым операндом.
Оператор x IN (<Список значений>)Оператор «содержится в списке» возвращает следующие значения:
• 1 (TRUE) – если х совпадает с одним из элементов списка;
• 0 (FALSE) – если х не совпадает ни с одним из элементов списка;
• NULL – если х равен NULL, а также в тех случаях, когда в списке присутствует значение NULL и при этом
возвращает результат, представленный в табл. 3.12.
Оператор IN позволяет также сравнивать составные значения, то есть значение х и элементы списка могут представлять собой наборы из нескольких величин (количество компонентов во всех наборах должно быть одинаковым).
Например, запроссравнивает каждую пару, состоящую из даты заказа (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 и при этом
возвращает результат, представленный в табл. 3.11.
Этот оператор, как и оператор IN, может работать с составными значениями, а также со списком, полученным в результате подзапроса.
Следующий оператор проверяет соответствие первого операнда шаблону, который является вторым операндом.
Оператор x LIKE yОператор сравнения с шаблоном возвращает следующие значения:
• 1 (TRUE) – если х соответствует шаблону у;
• 0 (FALSE) – если х не соответствует шаблону у;
• NULL – если х или
В шаблоне можно использовать два специальных подстановочных символа:
• % – на месте знака процента может быть любое количество произвольных символов операнда
• _ – на месте знака подчеркивания может быть ровно один произвольный символ операнда
Результат этого запроса представлен в табл. 3.14. Таблица 3.14. Результат выполнения запроса
Если требуется включить в шаблон знак процента или подчеркивания, которые должны рассматриваться не как подстановочные, а как обычные символы, перед ними нужно поставить обратную косую черту («\%», «\_»). Если же шаблон должен содержать символ обратной косой черты, то ее нужно удвоить («\»). Например, значение выражения \_% LIKE \\_\% истинное.
По умолчанию сравнение с помощью оператора LIKE выполняется без учета регистра символов (то есть заглавная и строчная буквы рассматриваются как одинаковые). Для сравнения с учетом регистра (чтобы заглавная и строчная буквы рассматривались как разные) необходимо указать ключевое слово BINARY или правило сравнения (COLLATE). Например, выражение 'Крылов' LIKE 'крылов' истинно, а выражения 'Крылов' LIKE BINARY 'крылов' и 'Крылов' LIKE 'крылов' COLLATE utf8_bin ложны (правило сравнения должно соответствовать кодировке, в которой работает ваше клиентское приложение; правила сравнения мы рассмотрели в разделе «Создание базы данных» главы 2).Примечание
Более сложные шаблоны вы можете создавать с помощью регулярных выражений. Регулярные выражения представляют собой универсальный язык описания текстов. Информацию о синтаксисе регулярных выражений вы можете найти на веб-странице http://ru.wikipedia.org/wiki/Регулярные_выражения. Для сравнения строки с шаблоном, содержащим регулярные выражения, необходимо вместо оператора LIKE использовать оператор REGEXP.
Следующий оператор проверяет несоответствие первого операнда шаблону, который является вторым операндом.
Оператор x NOT LIKE y
Оператор NOT LIKE возвращает результат, противоположный результату выполнения оператора LIKE:
• значение 0 (FALSE) – если х соответствует шаблону у;
• значение 1 (TRUE) – если х не соответствует шаблону;
• значение NULL – если х или
Например, следующий запрос выводит данные о тех клиентах, чьи имена не содержат кавычек:
Результат этого запроса представлен в табл. 3.15. Таблица 3.15. Результат выполнения запроса
К операторам сравнения близка функция STRCMP(), которую мы также рассмотрим в этом разделе, несмотря на то что она может возвращать, помимо значений 1 (TRUE), 0 (FALSE) и NULL, значение – 1 (TRUE).
Оператор STRCMP(x,y)Функция STRCMP() сравнивает строки х и
• – 1 – если х предшествует
• 0 – если х и
• 1 – если х следует после
• NULL – если по крайней мере один из аргументов равен NULL.
Например, зададим для таблицы Customers (Клиенты) правило сравнения, не учитывающее регистр:В этом случае запрос
возвращает результат, представленный в табл. 3.16. Таблица 3.16. Результат выполнения запроса
Зададим для таблицы Customers правило сравнения, учитывающее регистр:В итоге тот же самый запрос вернет уже другой результат (табл. 3.17): Таблица 3.17. Результат выполнения запроса
Различие результатов объясняется тем, что без учета регистра строки «Крылов» и «крылов» эквивалентны, а с учетом регистра – различны.
При использовании сравнения по числовым кодам символов мы получим третий результат, отличающийся от первых двух.Результат этого запроса представлен в табл. 3.18. Таблица 3.18. Результат выполнения запроса
Наконец, рассмотрим оператор полнотекстового поиска.
Оператор MATCH (<Список столбцов>) AGAINST