Результат этого запроса представлен в табл. 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. Результат выполнения запроса