Читаем MySQL 5.0. Библиотека программиста полностью

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

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

SELECT * FROM Customers WHERE name NOT LIKE \'%»%\

Результат этого запроса представлен в табл. 3.15. Таблица 3.15. Результат выполнения запроса

К операторам сравнения близка функция STRCMP(), которую мы также рассмотрим в этом разделе, несмотря на то что она может возвращать, помимо значений 1 (TRUE), 0 (FALSE) и NULL, значение – 1 (TRUE).

Оператор STRCMP(x,y)

Функция STRCMP() сравнивает строки х и у в соответствии с текущими правилами сравнения и возвращает:

• – 1 – если х предшествует у в алфавитном порядке;

• 0 – если х и у совпадают;

• 1 – если х следует после у в алфавитном порядке;

• NULL – если по крайней мере один из аргументов равен NULL.

Например, зададим для таблицы Customers (Клиенты) правило сравнения, не учитывающее регистр:

ALTER TABLE Customers CONVERT TO CHARACTER SET cp1251 COLLATE cp1251_general_ci;

В этом случае запрос

SELECT name, STRCMP(name,\'крылов\') FROM Customers;

возвращает результат, представленный в табл. 3.16. Таблица 3.16. Результат выполнения запроса

Зададим для таблицы Customers правило сравнения, учитывающее регистр:

ALTER TABLE Customers

CONVERT TO CHARACTER SET cp1251 COLLATE cp1251_general_cs;

SELECT name, STRCMP(name,\'крылов\') FROM Customers;

Перейти на страницу:

Похожие книги

1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных
97 этюдов для архитекторов программных систем
97 этюдов для архитекторов программных систем

Успешная карьера архитектора программного обеспечения требует хорошего владения как технической, так и деловой сторонами вопросов, связанных с проектированием архитектуры. В этой необычной книге ведущие архитекторы ПО со всего света обсуждают важные принципы разработки, выходящие далеко за пределы чисто технических вопросов.?Архитектор ПО выполняет роль посредника между командой разработчиков и бизнес-руководством компании, поэтому чтобы добиться успеха в этой профессии, необходимо не только овладеть различными технологиями, но и обеспечить работу над проектом в соответствии с бизнес-целями. В книге более 50 архитекторов рассказывают о том, что считают самым важным в своей работе, дают советы, как организовать общение с другими участниками проекта, как снизить сложность архитектуры, как оказывать поддержку разработчикам. Они щедро делятся множеством полезных идей и приемов, которые вынесли из своего многолетнего опыта. Авторы надеются, что книга станет источником вдохновения и руководством к действию для многих профессиональных программистов.

Билл де Ора , Майкл Хайгард , Нил Форд

Программирование, программы, базы данных / Базы данных / Программирование / Книги по IT