LIKE SQL Server — Oracle PL/SQL •MySQL •MariaDB •SQL Server •SQLite
В этом учебном пособии вы узнаете, как использовать в SQL Server условие LIKE (Transact-SQL) для выполнения сопоставления с шаблоном с синтаксисом и примерами.
Описание
Условие LIKE SQL Server (Transact-SQL) определяет, совпадает ли указанная символьная строка с заданным шаблоном в предложении WHERE в операторе SELECT, INSERT, UPDATE или DELETE. Это позволяет выполнять сопоставление образцов.
Синтаксис
Синтаксис условия LIKE в SQL Server (Transact-SQL):
expression LIKE pattern [ ESCAPE ‘escape_character’ ]
Параметры или аргументы
expression — символьное выражение, такое как столбец или поле.
pattern — символьное выражение, содержащее подстановочный символ. Подстановочные символы, которые вы можете выбрать:
символ | пояснение |
---|---|
% | Позволяет вам сопоставлять любую строку любой длины (включая нулевую длину) |
_ | Позволяет вам сопоставлять один символ |
[ ] | Позволяет вам сопоставлять любой символ в скобках [] (например, [abc] будет соответствовать символам a, b или c) |
[^] | Позволяет вам сопоставлять любой символ, не находящийся в скобках [^] (например, [^ abc] будет соответствовать любому символу, который не является символом a, b или c) |
escape_character — необязательный. Это позволяет вам проверять для буквенных экземпляров символа подстановки, например % или _.
Пример использования подстановочного символа % (символ процента)
Первый пример SQL Server LIKE, который мы рассмотрим, включает использование шаблона %.
Давайте объясним, как шаблон % работает в SQL Server условии LIKE. Мы хотим найти всех employees (сотрудников), чье имя last_name начинается с ‘Б’.
Например:
SELECT * FROM employees WHERE last_name LIKE ‘Б%’;
SELECT * FROM employees WHERE last_name LIKE ‘Б%’; |
Этот пример условия SQL Server LIKE вернет всех employees у которых last_name будет начинаться на ‘Б’ такие как ‘Брошкин’, ‘Баранников’, ‘Богомолец’ и т.д.
Вы также можете использовать групповой символ % несколько раз в одной строке. Например:
SELECT * FROM employees WHERE last_name LIKE ‘%o%’;
SELECT * FROM employees WHERE last_name LIKE ‘%o%’; |
В этом примере SQL LIKE мы ищем всех employees (сотрудников), у которых last_name содержит букву ‘o’.
Пример использования подстановочного символа _ (символ подчеркивания)
Затем давайте объясним, как подстановочный символ _ (символ подчеркивания) работает в условии SQL Server LIKE. Помните, что _ ищет только один символ.
Например:
SELECT * FROM employees WHERE last_name LIKE ‘Кр_т’;
SELECT * FROM employees WHERE last_name LIKE ‘Кр_т’; |
Этот пример условия SQL LIKE возвращает всех employees (сотрудников), чье имя last_name равно 4 символам, причем первые два символа — «Кр», а последний символ — «т». Например, он может вернуть сотрудников, чье last_name является «Крот», «Крат», «Крут», «Крит» и т.д.
Вот еще один пример:
Transact-SQLSELECT * FROM employees WHERE employee_number LIKE ‘123_’;
SELECT * FROM employees WHERE employee_number LIKE ‘123_’; |
Вам может понадобиться найти номер employee_number, но у вас есть только 3 из 4 цифр. В приведенном выше примере будет извлечено потенциально 10 записей (где отсутствующее значение могло бы равняться чему угодно от 0 до 9). Например, он может вернуть employees, чьи employee_number:
1230, 1231, 1232, 1233, 1234, 1235, 1236, 1237, 1238, 1239
Пример использования подстановочного символа [] (квадратные скобки).
Далее, давайте объясним, как подстановочный символ [] (квадратные скобки) работает в условии SQL Server LIKE. Помните, что то, что содержится в квадратных скобках, это символы, которые вы пытаетесь сопоставить.
Например:
SELECT * FROM employees WHERE first_name LIKE ‘К[ио]тов’;
SELECT * FROM employees WHERE first_name LIKE ‘К[ио]тов’; |
Этот пример условия LIKE SQL Server возвращает всех employees, чье имя first_name равно 5 символам, причем первый символ — «К», а три последних символа — «тов», а второй символ — «и» или «о». ио]тов’;
Этот пример условия SQL Server LIKE возвращает всех сотрудников, чье имя first_name равно 5 символам, причем первый символ — «К», а три последних символа — «тов», а второй символ не является «и» или «о». Таким образом, в этом случае он будет соответствовать таким значениям, как «Катов», «Кутов», «Кетов» и т.д. Но это не будет соответствовать ни «Китов», ни «Котов».
Пример использования оператора NOT
Затем давайте посмотрим, как использовать SQL Server NOT Operator с помощью подстановочных символов.
Будем использовать % с оператором NOT. Вы также можете использовать условие SQL LIKE для поиска employees (сотрудников), имя которых не начинается с буквы «Б».
Например:
SELECT * FROM employees WHERE last_name NOT LIKE ‘Б%’;
SELECT * FROM employees WHERE last_name NOT LIKE ‘Б%’; |
Поместив оператор NOT перед условием LIKE SQL Server, вы сможете получить всех employees, имя которых не начинается с «Б».
Пример использования символов Escape
Важно понимать, как сопоставить «Escape Characters» с pattern. Эти примеры относятся конкретно к экранирующим символам в SQL Server.
Предположим, вы хотели найти символ % или _ в условии SQL Server LIKE. Вы можете сделать это, используя символ Escape.
Обратите внимание, что вы можете определить escape-символ только как один символ (length = 1).
Например:
SELECT * FROM employees WHERE secret_hint LIKE ‘123!%455’ ESCAPE ‘!’;
SELECT * FROM employees WHERE secret_hint LIKE ‘123!%455’ ESCAPE ‘!’; |
Этот пример условия SQL LIKE идентифицирует символ ! как escape-символ. Это предложение вернет всех employees, чей secret_hint составляет 123%455.
Вот еще один более сложный пример использования escape-символов в SQL Server условии LIKE.
Transact-SQLSELECT * FROM employees WHERE secret_hint LIKE ‘H%!%’ ESCAPE ‘!’;
SELECT * FROM employees WHERE secret_hint LIKE ‘H%!%’ ESCAPE ‘!’; |
Этот пример условия SQL LIKE возвращает всех employees, чей secret_hint начинается с ‘H’ и заканчивается на ‘%’. Например, он возвращает значение, например «Help%».
Вы также можете использовать escape-символ с символом _ в условии SQL Server LIKE.
Например:
SELECT * FROM employees WHERE secret_hint LIKE ‘H%!_’ ESCAPE ‘!’;
SELECT * FROM employees WHERE secret_hint LIKE ‘H%!_’ ESCAPE ‘!’; |
Этот пример условия SQL LIKE возвращает всех employees, чей secret_hint начинается с ‘H’ и заканчивается на ‘_’. Например, он вернет значение, например «Help_».
Как использовать оператор SQL LIKE в MongoDB
MongoDB — мощный сервер базы данных Nosql. Он использует документы, подобные JSON, с дополнительными схемами для хранения данных.
Организация данных всегда является важной задачей разработчика. Поскольку он играет важнейшую роль в производительности приложения. В Mongodb вы можете использовать запросы, похожие на оператор SQL LIKE, для извлечения данных.
В примерах, используемых в этом руководстве, мы используем некоторые фиктивные данные, как показано ниже. Вы также можете создать базу данных и выполнить приведенные ниже команды для вставки фиктивных данных.
db.colors.insert({ "id": 100, "color": "Pink"}) db.colors.insert({ "id": 101, "color": "Purple"}) db.colors.insert({ "id": 102, "color": "Black"}) db.colors.insert({ "id": 103, "color": "Blue"})
Использование .find()
Команда Mongodb find() используется для поиска документов в коллекции. Эта функция предоставляет гибкие возможности поиска документов.
Функция find() по умолчанию извлекает все документы в коллекции. Он также позволяет запрашивать коллекцию документов, передавая несколько простых параметров, и возвращать курсор.
Простой пример метода .find() выглядит так:
db.colors.find()
{"_id": ObjectId ("5f697e4ccc528930cde49f53"), "id": 100, "color": "Pink"} {"_id": ObjectId ("5f697e4fcc528930cde49f54"), "id": 101, "color": "Purple"} {"_id": ObjectId ("5f697e52cc528930cde49f55"), "id": 102, "color": "Черный"} {"_id": ObjectId ("5f697e55cc528930cde49f56"), "id": 103, "color": "Синий"}
Вышеупомянутое возвращает все документы в коллекции.
Search String End With — символ доллара «$» используется для сопоставления конца строки с определенными символами. В приведенном ниже примере все строки заканчиваются символом «k».
### SQL Statement select * from colors where color LIKE "%k" ### Mongodb Statement db.colors.find(color: "/k$/")
Search String In Any Case — это метод поиска по умолчанию с учетом регистра символов. Вы можете поручить команде find в любом случае сопоставить символы с параметром «i», как это используется в приведенном ниже примере.
### SQL Statement select * from colors where color LIKE BINARY "pink" ### Mongodb Statement db.colors.find(color: "/pink/i")
Как найти шаблоны с помощью SQL LIKE
Люди, часто работающие с данными, обнаруживают, что им часто приходится запрашивать определенные типы. SQL предоставляет нам множество инструментов для достижения этой цели. Эти инструменты, такие как SQL LIKE, помогают нам рассматривать определенные типы данных, а не всю базу данных.
Это сокращает время и усилия, затрачиваемые на выполнение той или иной задачи, и дает людям возможность работать более эффективно.В этой статье SQL LIKE вы узнаете, как запрашивать данные для поиска определенных шаблонов.
Что такое SQL?
Оператор LIKE используется для поиска определенных символов в столбцах таблицы. Он также используется для сравнения столбцов с указанными значениями.
Вместе с предложением WHERE он определяет, соответствует ли шаблон определенным значениям в таблице. Для этой цели он использует подстановочные знаки, которые используются для замены одного или нескольких символов в строке. Вы также можете использовать LIKE, когда известна только часть значений в таблице.
Давайте рассмотрим синтаксис этого оператора.
Синтаксис для использования SQL LIKE
Оператор SQL LIKE обычно используется с командой SELECT. Синтаксис этого следующий:
ВЫБРАТЬ столбец_1, столбец_2,. .. столбец_n ОТ имя_таблицы ГДЕ столбец_1 НРАВИТСЯ [шаблон]; |
- Столбцы для отображения в таблице результатов указываются после оператора SELECT
- Таблица указана в параметре table_name оператора FROM
- Столбец, предназначенный для сопоставления с образцом, указан в предложении WHERE .
- Шаблон формируется из определенного выбора строки, который определен в параметре [pattern] оператора LIKE
ПРИМЕЧАНИЕ. Оператор LIKE нечувствителен к регистру.
С помощью этого оператора можно указать несколько шаблонов, используя ключевые слова «И» или «ИЛИ».
Подстановочные знаки являются наиболее важными инструментами этого оператора, поэтому давайте рассмотрим, что это такое и как они используются с LIKE.
подстановочных знаков, используемых с LIKE
Подстановочные знаки — это специальные символы и символы, используемые для представления одного или нескольких символов в строке. Они обязательны для оператора LIKE, так как позволяют указывать шаблоны.
Два подстановочных знака, используемые с оператором LIKE, следующие:
- % (знак процента). Используется для представления нуля или более символов.
- _ (подчеркивание) — каждое подчеркивание представляет ровно один символ.
Чтобы получить более четкое представление об этих подстановочных знаках, давайте рассмотрим несколько примеров их использования в операторах.
Важно заключать все шаблоны в одинарные кавычки; в противном случае запрос вернет синтаксическую ошибку.
Заявление | Описание |
ГДЕ имя_столбца КАК ‘a%’ | Возвращает любые значения, начинающиеся с «а» |
ГДЕ имя_столбца КАК ‘%sh’ | Возвращает любые значения, оканчивающиеся на «ш». |
ГДЕ имя_столбца НРАВИТСЯ %a% | Возвращает любые значения, содержащие букву . |
ГДЕ имя_столбца НРАВИТСЯ ‘_’ | Возвращает любые значения, содержащие только один символ |
ГДЕ имя_столбца НРАВИТСЯ ‘__a%’ | Возвращает любые значения, которые содержат «а» в качестве третьего символа |
ГДЕ имя_столбца КАК ‘b%n’ | Возвращает любые значения, начинающиеся с «b» и заканчивающиеся на «n». |
ГДЕ имя_столбца НРАВИТСЯ ‘_%__a’ | Возвращает значения, содержащие не менее трех символов и заканчивающиеся на «а». |
ГДЕ имя_столбца НРАВИТСЯ ‘a___c | Возвращает значения, начинающиеся с «а» и заканчивающиеся на «с», и содержащие пять символов |
Чтобы получить более полное представление о том, как использовать SQL LIKE, давайте запросим таблицу.
Использование LIKE для столбцов таблицы
Возьмем образец из следующей таблицы:
- Из этой таблицы, если вы хотите узнать «EmployeeID» всех сотрудников, чьи имена начинаются с буквы «А», вы должны использовать следующий запрос:
Вы также можете использовать «a» вместо «A», потому что оператор LIKE не чувствителен к регистру.
Приведенный выше запрос приведет к следующей таблице:
- Чтобы определить, у какого сотрудника название города начинается с «b» и заканчивается на «e», вам необходимо ввести следующий код:
В результате получится следующая таблица:
Это показывает, что возвращаемые города содержат указанный шаблон. Чтобы увидеть, какие города содержат только два символа, введите следующий код, в котором используются два знака подчеркивания, заключенные в кавычки:
Приведенный выше запрос возвращает следующую таблицу:
Это показывает, что таблица содержит только две записи, тогда как атрибут города содержит только два символа.
- Оператор LIKE можно использовать с любым типом данных
Следующий код поможет пользователю найти все записи, содержащие двузначные идентификаторы сотрудников:
Это приведет к следующему:
Это показывает, что таблица «Сотрудник» содержит только одну запись с двузначным идентификатором сотрудника.
Следующий код используется для целевых сотрудников с окладами от 50000 до 59000:
В этом запросе использовалось десятичное число и два знака подчеркивания после десятичного числа. Это связано с тем, что оклады являются одним из десятичных типов данных, наряду с двумя цифрами после запятой, и шаблон должен напоминать это представление в таблице.
Приведенный выше запрос вернет следующую таблицу:
- Вы также можете использовать ключевое слово «НЕ» перед LIKE, чтобы выбрать все записи, которые не соответствуют указанному шаблону
Например, если вы хотите найти все записи, соответствующие сотрудникам, чьи имена начинаются со всех остальных букв, кроме «А», введите следующее:
В результате получится следующая таблица:
В результатах отображаются все записи, не начинающиеся с буквы «А».
- Вы также можете использовать ключевые слова «И» или «ИЛИ», чтобы указать более одного шаблона в одном запросе
Например, чтобы узнать, имена каких сотрудников начинаются с «А» или «Н», введите следующее:
В результате получится следующая таблица:
Все записи, отображаемые в результатах, соответствуют спецификациям шаблона из исходного запроса. Также обязательно нужно заключить шаблон в одинарные кавычки.
Система возвращает синтаксическую ошибку, если шаблон не заключен в одинарные кавычки.
Получите опыт работы с новейшими инструментами и методами бизнес-аналитики с помощью магистерской программы для бизнес-аналитиков. Зарегистрируйтесь сейчас!
Следующие шаги
SQL LIKE упрощает для пользователей определение шаблонов в столбцах таблицы. Это простой в использовании мощный инструмент, доступный всем, кто использует SQL для управления данными.
Теперь, когда вы знаете об операторе LIKE, пришло время начать запрашивать и манипулировать данными, чтобы находить различные типы шаблонов с помощью различных команд, операторов и классов. Если вам понравилась эта статья и вы хотите пройти сертификацию, ознакомьтесь с нашей магистерской программой для бизнес-аналитиков, которая охватывает все, что вам нужно знать, чтобы стать экспертом по SQL.
У вас есть к нам вопросы? Оставьте их в разделе комментариев к нашей статье «Поиск шаблонов с помощью LIKE в SQL», и наши эксперты в этой области ответят на них за вас.
PostgreSQL LIKE — Запрос данных с использованием методов сопоставления с образцом
Резюме : в этом руководстве вы узнаете, как использовать операторы PostgreSQL LIKE и ILIKE
для запроса данных с использованием сопоставления с образцом.
Введение в оператор PostgreSQL LIKE
Предположим, вы хотите найти клиента, но точно не помните его имени. Однако вы просто помните, что ее имя начинается примерно с Джен
.
Как найти точного клиента из базы данных? Вы можете найти клиента в таблице клиентов
, взглянув на столбец имени, чтобы увидеть, есть ли какое-либо значение, начинающееся с Джен
. Это займет много времени, если в таблице клиентов много строк.
К счастью, вы можете использовать PostgreSQL LIKE
оператор для сопоставления имени клиента со строкой, подобной этому запросу:
SELECT имя, фамилия ОТ клиент ГДЕ first_name НРАВИТСЯ 'Джен%'; Язык кода: SQL (язык структурированных запросов) (sql)
Обратите внимание, что предложение WHERE
содержит специальное выражение: first_name
, оператор LIKE
и строку, содержащую знак процента (%
). Строка 'Jen%'
называется шаблоном.
Запрос возвращает строки, значения которых в столбце first_name начинаются с Jen
и могут сопровождаться любой последовательностью символов. Этот метод называется сопоставлением с образцом.
Вы создаете шаблон, комбинируя буквенные значения с подстановочными знаками и используя оператор LIKE
или NOT LIKE
для поиска совпадений. PostgreSQL предоставляет вам два подстановочных знака:
- Знак процента (
%
) соответствует любой последовательности из нуля или более символов. - Знак подчеркивания (
_
) соответствует любому одиночному символу.
Синтаксис оператора PostgreSQL LIKE
следующий:
значение LIKE шаблон Язык кода: SQL (язык структурированных запросов) (sql)
Выражение возвращает значение true, если значение
соответствует шаблон
.
Для инвертирования оператора LIKE
используется оператор NOT
следующим образом:
значение NOT LIKE шаблон Язык кода: SQL (язык структурированных запросов) (sql)
Оператор NOT LIKE
возвращает значение true, если значение
не соответствует шаблону
.
Если шаблон не содержит подстановочных знаков, оператор LIKE
ведет себя как оператор равенства ( =
).
Оператор LIKE в PostgreSQL — примеры сопоставления с образцом
Рассмотрим несколько примеров использования оператора LIKE
Примеры LIKE в PostgreSQL
См. следующий пример:
ВЫБОР 'foo' КАК 'foo', -- верно 'foo' КАК 'f%', -- верно 'foo' КАК '_o_', -- правда 'бар' КАК 'b_'; -- false Язык кода: SQL (язык структурированных запросов) (sql)
Как это работает.
- Первое выражение возвращает значение true, поскольку шаблон
foo
не содержит подстановочных знаков, поэтому операторLIKE
действует как оператор равенства (=
). - Второе выражение возвращает значение true, поскольку оно соответствует любой строке, начинающейся с буквы 9.0269 f и любое количество символов.
- Третье выражение возвращает значение true, поскольку шаблон (
_o_
) соответствует любой строке, которая начинается с любого одиночного символа, за которой следует букваили
и заканчивается любым одиночным символом. - Четвертое выражение возвращает false, поскольку шаблон
b_
соответствует любой строке, начинающейся с буквыb
, за которой следует любой одиночный символ.
Можно использовать подстановочные знаки в начале и/или конце шаблона.
Например, следующий запрос возвращает клиентов, чье имя содержит строку или
, например Дженифер
, Кимберли
и т. д.
SELECT имя, фамилия ОТ клиент ГДЕ first_name НРАВИТСЯ '%er%' СОРТИРОВАТЬ ПО имя; Язык кода: SQL (язык структурированных запросов) (sql)
Вы можете комбинировать процент ( %
) с символом подчеркивания ( _
), чтобы создать шаблон, как показано в следующем примере:
ВЫБОР имя, фамилия ОТ клиент ГДЕ first_name НРАВИТСЯ '_her%' СОРТИРОВАТЬ ПО имя; Язык кода: SQL (язык структурированных запросов) (sql)
Шаблон _her%
соответствует любой строке, которая:
- Начинается с любого одиночного символа (
_
) - И за которым следует литр аль строка
ее
. - И заканчивается любым количеством символов.
Возвращаемые имена C ее yl, S ее ri, S ее ry и T ее asa.
PostgreSQL NOT LIKE примеры
Следующий запрос использует оператор NOT LIKE
для поиска клиентов, чьи имена не начинаются с Jen
:
SELECT имя, фамилия ОТ клиент ГДЕ first_name НЕ НРАВИТСЯ 'Джен%' СОРТИРОВАТЬ ПО first_name Язык кода: SQL (язык структурированных запросов) (sql)
Расширения PostgreSQL оператора LIKE
PostgreSQL поддерживает оператор ILIKE
, который работает аналогично оператору LIKE
. Кроме того, оператор ILIKE
сопоставляет значение без учета регистра. Например:
ВЫБЕРИТЕ имя, фамилия ОТ клиент ГДЕ first_name ILIKE 'BAR%'; Язык кода: SQL (язык структурированных запросов) (sql)
Шаблон BAR%
соответствует любой строке, которая начинается с BAR
, Bar
, BaR
и т.