LIKE условие MySQL — Oracle PL/SQL •MySQL •MariaDB •SQL Server •SQLite
В этом учебном пособии вы узнаете, как использовать MySQL условие LIKE для выполнения сопоставления шаблонов с синтаксисом и примерами.
Описание
MySQL условие LIKE позволяет использовать шаблоны в операторе WHERE для оператора SELECT, INSERT, UPDATE или DELETE. Это позволяет выполнять сопоставление шаблонов.
Синтаксис
Синтаксис условия LIKE в MySQL:
expression LIKE pattern [ ESCAPE ‘escape_character’ ]
Параметры или аргументы
expression — символьное выражение, такое как столбец или поле.
pattern — символьное выражение, содержащее сопоставление шаблонов. Шаблоны, которые вы можете выбрать:
% — позволяет вам сопоставлять любую строку любой длины (включая нулевую длину)
_ — позволяет вам сопоставлять один символ
escape_character — необязательный. Это позволяет вам проверять для буквенных экземпляров символы подстановки, такие как % или _. Если вы не укажите escape_character, MySQL предположит, что \ является escape_character.
Пример использования символа % (подстановочный символ процента)
Первый MySQL пример LIKE, который мы рассмотрим, включает использование % (подстановочный символ процента).
Рассмотрим как % работает в MySQL условии LIKE. Мы хотим найти всех customers, last_name которых начинается с «Ber».
SELECT customer_name FROM customers WHERE last_name LIKE ‘Ber%’;
SELECT customer_name FROM customers WHERE last_name LIKE ‘Ber%’; |
Вы также можете использовать % несколько раз в одной строке.
Например:
SELECT customer_name FROM customers WHERE last_name LIKE ‘%ns%’;
SELECT customer_name FROM customers WHERE last_name LIKE ‘%ns%’; |
В этом примере MySQL условия LIKE мы ищем всех customers, у которых last_name содержит символы ‘ns’.
Пример использования подстановочного символа _ (подстановочный символ подчеркивания)
Рассмотрим, как знак _ (подстановочный символ подчеркивания) работает в MySQL условии LIKE. Помните, что подстановочный символ _ означает только один символ.
Например:
SELECT supplier_name FROM suppliers WHERE supplier_name LIKE ‘Ber_ard’;
SELECT supplier_name FROM suppliers WHERE supplier_name LIKE ‘Ber_ard’; |
Этот пример MySQL условия LIKE возвращает всех suppliers, supplier_name которых составляет 7 символов, причем первые три символа — «Ber», а последние три символа — «ard». Например, он может вернуть всех, supplier_name которых — ‘Bernard’, ‘Berzard’, ‘Bermard’, ‘Bersard’ и т.д.
И еще один пример:
SELECT * FROM suppliers WHERE account_number LIKE ‘12345_’;
SELECT * FROM suppliers WHERE account_number LIKE ‘12345_’; |
Вам может понадобиться найти номер учетной записи, но у вас есть только 5 из 6 цифр. В приведенном выше примере будет извлечено потенциально 10 записей (где отсутствующее значение могло бы равняться чему угодно от 0 до 9). Например, запрос может вернуть suppliers, чьи номера учетной записи: 123450, 123451, 123452, 123453, 123454, 123455, 123456, 123457, 123458, 123459
Пример использования оператора NOT
Рассмотрим, как вы будете использовать оператор NOT с подстановочными символами.
Давайте использовать подстановочный символ % с оператором NOT. Вы также можете использовать MySQL условие LIKE для поиска suppliers, supplier_name которых не начинается с «B».
Например:
SELECT supplier_name FROM suppliers WHERE supplier_name NOT LIKE ‘B%’;
SELECT supplier_name FROM suppliers WHERE supplier_name NOT LIKE ‘B%’; |
Помещая оператора NOT перед MySQL условием LIKE, вы получите всех suppliers, supplier_name которых не начинается с «B».
Пример использования символов Escape
Важно понять, каким образом «Escape Characters» сравнивается с шаблоном. Эти примеры относятся конкретно к экранирующим символам в MySQL.
Предположим, вы хотели найти символы % или _ в MySQL условии LIKE. Вы можете сделать это, используя символ Escape.
Обратите внимание, что вы можете определить только escape-символ как один символ (длина 1).
Например:
SELECT * FROM suppliers WHERE supplier_name LIKE ‘B\%’;
SELECT * FROM suppliers WHERE supplier_name LIKE ‘B\%’; |
Поскольку мы не указали каким будет escape-символ, то MySQL предполагает, что «\» и является escape-символом. Т.к. MySQL предположил, что «\» это и есть escape-символ, что приведет к тому, что MySQL обработает символ % как литерал, вместо подстановочного символа. Затем этот запрос будет возвращать всех suppliers, у которых supplier_name = ‘B\%’.
Мы можем переопределить escape-символ по умолчанию в MySQL, предоставив модификатор ESCAPE следующим образом:
SELECT * FROM suppliers WHERE supplier_name LIKE ‘Br!%’ ESCAPE ‘!’;
SELECT * FROM suppliers WHERE supplier_name LIKE ‘Br!%’ ESCAPE ‘!’; |
Этот пример MySQL условия LIKE идентифицирует символ ! как escape-символ. Escape-символ ! приведет к тому, что MySQL обрабатывает символ % как литерал. В результате в этом запросе также будут выбраны все suppliers, supplier_name которых Br%.
Вот еще один более сложный пример использования escape-символов в MySQL условии LIKE.
SELECT * FROM suppliers WHERE supplier_name LIKE ‘H%\%’;
SELECT * FROM suppliers WHERE supplier_name LIKE ‘H%\%’; |
Этот пример условия LIKE MySQL возвращает всех suppliers, чье имя начинается с H и заканчивается на %. Например, он вернет значение, например «Hello%». Поскольку мы не указывали escape-символ в условии LIKE, MySQL предполагает, что escape-символ «\», что приводит к тому, что MySQL обрабатывает второй символ % как литерал вместо подстановочного символа.
Мы могли бы изменить это условие LIKE, указав escape-символ следующим образом:
SELECT * FROM suppliers WHERE supplier_name LIKE ‘H%!%’ ESCAPE ‘!’;
SELECT * FROM suppliers WHERE supplier_name LIKE ‘H%!%’ ESCAPE ‘!’; |
Этот пример MySQL условия LIKE возвращает всех suppliers, имя которых начинается с H и заканчивается символом %. Например, он вернет значение, например «Hello%».
Вы также можете использовать escape character с символом _ в MySQL условии LIKE.
Например:
SELECT * FROM suppliers WHERE supplier_name LIKE ‘H%\_’;
SELECT * FROM suppliers WHERE supplier_name LIKE ‘H%\_’; |
Опять же, поскольку не предусмотрен модификатор ESCAPE, MySQL использует «\» в качестве символа escape, в результате чего символ _ обрабатывается как литерал вместо подстановочного символа. В этом примере будут возвращены все suppliers, supplier_name которых начинается с H и заканчивается на _. Например, запрос вернет значение, такое как «Hello_».
Использование условия SQL like для сравнения значений: синтаксис и примеры
От автора: условие SQL LIKE используется для сравнения значения с аналогичными значениями с использованием подстановочных операторов. В сочетании с оператором LIKE используются два подстановочных знака. Знак процента (%). Подчеркивание (_).
Знак процента представляет ноль, один или несколько символов. Символ подчеркивания представляет одно число или символ. Эти символы могут использоваться в различных комбинациях.
Синтаксис
SELECT FROM table_name WHERE column LIKE ‘XXXX%’ или SELECT FROM table_name WHERE column LIKE ‘%XXXX%’ или SELECT FROM table_name WHERE column LIKE ‘XXXX_’ или SELECT FROM table_name WHERE column LIKE ‘_XXXX’ или SELECT FROM table_name WHERE column LIKE ‘_XXXX_’
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | SELECT FROM table_name WHERE column LIKE ‘XXXX%’
или
SELECT FROM table_name WHERE column LIKE ‘%XXXX%’
или
SELECT FROM table_name WHERE column LIKE ‘XXXX_’
или
SELECT FROM table_name WHERE column LIKE ‘_XXXX’
или
SELECT FROM table_name WHERE column LIKE ‘_XXXX_’ |
С помощью операторов AND или OR вы можете комбинировать N-ное количество условий. Здесь XXXX может быть любым числовым или строковым значением.
Бесплатный курс по PHP программированию
Освойте курс и узнайте, как создать динамичный сайт на PHP и MySQL с полного нуля, используя модель MVC
В курсе 39 уроков | 15 часов видео | исходники для каждого урока
Получить курс сейчас!Пример
В следующей таблице приведено несколько примеров, в которых часть WHERE содержит разные условия LIKE с операторами «%» и «_»:
Давайте рассмотрим реальный пример. Возьмем таблицу CUSTOMERS, которая содержит следующие записи.
Ниже приведен код, который отображает все записи из таблицы CUSTOMERS, для которых значение в поле SALARY начинается с 200.
SELECT * FROM CUSTOMERS WHERE SALARY LIKE ‘200%’;
SELECT * FROM CUSTOMERS WHERE SALARY LIKE ‘200%’; |
Этот код дает следующий результат:
Источник: //www.tutorialspoint.com/
Редакция: Команда webformyself.
Бесплатный курс по PHP программированию
Освойте курс и узнайте, как создать динамичный сайт на PHP и MySQL с полного нуля, используя модель MVC
В курсе 39 уроков | 15 часов видео | исходники для каждого урока
Получить курс сейчас!Хотите изучить MySQL?
Посмотрите курс по базе данных MySQL!
СмотретьMs sql like синтаксис
Содержание
Польза предложения LIKE основывается на поддерживаемых им обобщающих операторах. Предложение LIKE возвращает булево значение ИСТИНА, если при сравнении обнаруживаются совпадающие значения.
Для функционирования предложения LIKE очень важна чувствительность к регистру конкретной СУБД. Например, Microsoft SQL Server по умолчанию не учитывает регистр (хотя его можно настроить соответствующим образом). Таким образом, SQL Server будет считать строки DAD и dad одинаковыми. С другой стороны, платформа Oracle учитывает регистр, и строки DAD и dad здесь будут разными. Вот пример, позволяющий лучше проиллюстрировать это положение.
Этот запрос для Microsoft SQL Server извлечет из таблицы authors записи, где фамилия (lname) имеет вид ‘larson’ или ‘lars’, хотя в запросе поиск определен с использованием верхнего регистра (‘LARS%’). В Oracle этот запрос не найдет фамилий ‘Larson’ или ‘Lars’, поскольку Oracle производит сравнение с учетом регистра.
Платформа DB2 поддерживает синтаксис предложения LIKE стандарта ANSI SQL 2003. Поддерживаются обобщающие символы % и знак подчеркивания (_). Поддерживаются отменяющие последовательности.
Платформа DB2 учитывает регистр, поэтому здесь реализация предложения LIKE полностью чувствительна к регистру. Чтобы значения в разных регистрах всегда сравнивались без учета регистра, нужно использовать функцию UPPER или TRANSLATE. Кроме того, DB2 неявно преобразует кодовую страницу шаблона строки или отменяющей последователъности к кодовой странице выражения, если только они не определены с предложением FOR BIT DATA.
MySQL
Платформа MySQL поддерживает для предложения LIKE синтаксис стандарта ANSI. Поддерживаются обобщающие символы % и знак подчеркивания (_). Также поддерживается предложение ESCAPE.
Кроме того, MySQL поддерживает специальные функции REGEXP и NOT RLIKE, применяемые при проверке регулярных выражений. MySQL после версии 3.23.4 по умолчанию не учитывает регистр.
Oracle
Платформа Oracle поддерживает для предложения LIKE синтаксис стандарта ANSI. Поддерживаются обобщающие символы % и знак подчеркивания (_). Также поддерживается предложение ESCAPE. Синтаксис предложения LIKE в Oracle следующий.
LIKE4> строковый_шаблон [ESCAPE отменяющая_последовательность]
Специфичные для Oracle синтаксические элементы имеют следующие значения.
LIKEC
Используется полный набор символов UNICODE.
LIKE2
Используется набор символов UNICODE USC2.
LIKE4
Используется набор символов UNICODE USC4.
Поскольку платформа Oracle учитывает регистр, следует включать выражение, строковый_шаблон или и то и другое в функцию UPPER. В этом случае вы всегда будете сравнивать то, что нужно.
PostgreSQL
Платформа PostgreSQL поддерживает ANSI синтаксис предложения LIKE. Поддерживаются обобщающие символы % и знак подчеркивания (_). Также поддерживаются отменяющие последовательности.
PostgreSQL по умолчанию учитывает регистр. Для сравнения без учета регистра в PostgreSQL существует ключевое слово ILIKE. Также вы можете использовать оператор – как эквивалент LIKE и -* как эквивалент ILIKE, а также !- и !-* как эквиваленты NOT LIKE и NOT ILIKE соответственно. Это все расширения стандарта ANSI, которые существуют в PostgreSQL.
Например, следующие запросы функционально эквивалентны.
Поскольку в этих примерах используется нижний регистр, вы можете столкнуться с проблемой учета регистра. То есть запрос ведет поиск по строке ‘%ville’ в нижнем регистре, а таблица может содержать значения в верхнем регистре, которые не попадут в результаты – ‘BROWNSVILLE’, ‘NASHVILLE’, ‘HUNTSVILLE’. Эту проблему можно решить так, как показано в следующем примере.
Преобразуем значения в верхний регистр
Производим сравнение без учета регистра SELECT * FROM authors WHERE city
Вы должны знать (хотя это и выходит за рамки данной книги), что PostgreSQL также поддерживает регулярные выражения POSIX. Подробности приводятся в описании платформы.
SQL Server
Платформа SQL Server поддерживает ANSI синтаксис предложения LIKE. Поддерживаются отменяющие последовательности. Поддерживаются также следующие дополнительные обобщающие операторы.
[] – соответствует любому значению из указанного набора, например [abc], или диапазона, например [к-п].
[Л] – соответствует любому символу, не входящему в указанный набор или диапазон.
Используя дополнительные обобщающие операторы SQL Server, вы получаете дополнительные возможности. Например, вы можете извлечь записи об авторах, фамилии которых Carson, Carsen, Karson или Karsen.
Или вы можете извлечь записи об авторах, фамилии которых заканчиваются на «arson» или «arsen», но не Larsen или Larson.
Дополнительная информация по теме
Некоторые хитрости при использования инструкции REVOKE в базах данных на различных платформах
Некоторые советы использования инструкции MERGE в базах данных на различных платформах
Советы по использованию инструкции UPDATE в базах данных на самых разнообразных платформах
Некоторые особенности использования инструкции INSERT в базах данных на различных платформах
Оператор LIKE используется в предложении WHERE для поиска заданного шаблона в столбце.
В сочетании с оператором LIKE используются два подстановочных знака:
- % – Знак процента представляет нулевой, один или несколько символов
- _ – Подчеркнутый символ представляет собой один символ
Выражение | Описание |
WHERE name LIKE ‘text%’ | Находит любые значения, начинающиеся с «text» |
WHERE name LIKE ‘%text’ | Находит любые значения, заканчивающиеся на «text» |
WHERE name LIKE ‘%text%’ | Находит любые значения, которые имеют «text» в любой позиции |
WHERE name LIKE ‘_text%’ | Находит любые значения, которые имеют «text» во второй позиции |
WHERE name LIKE ‘text_%_%’ | Находит любые значения, начинающиеся с «text» и длиной не менее 3 символов |
WHERE name LIKE ‘text%data’ | Находит любые значения, начинающиеся с «text» и заканчивающиеся на «data» |
Примеры SQL LIKE
Следующий оператор SQL выбирает всех пользователей с именем name, начинающимся с «Т»:
Пример:
Следующий оператор SQL выбирает всех пользователей с именем name, заканчивающимся на «м»:
Пример:
Следующий оператор SQL выбирает всех пользователем с именем name, которое имеет «text» в любой позиции:
Пример:
Следующий оператор SQL выбирает всех пользователей с именем name, которое имеет «text» во второй позиции:
Пример:
Следующий оператор SQL выбирает всех пользователей с именем name, начинающимся с «Т» и длиной не менее 3 символов:
Пример:
Следующий оператор SQL выбирает всех пользователей с именем name, которое начинается с «Т» и заканчивается на «м»:
Пример:
Следующий оператор SQL выбирает всех пользователей с именем name, которое НЕ начинается с «Т»:
ОБЛАСТЬ ПРИМЕНЕНИЯ: SQL Server База данных SQL Azure Azure Synapse Analytics (хранилище данных SQL) Parallel Data Warehouse APPLIES TO: SQL Server Azure SQL Database Azure Synapse Analytics (SQL DW) Parallel Data Warehouse
Определяет, совпадает ли указанная символьная строка с заданным шаблоном. Determines whether a specific character string matches a specified pattern. Шаблон может включать обычные символы и символы-шаблоны. A pattern can include regular characters and wildcard characters. Во время сравнения с шаблоном необходимо, чтобы его обычные символы в точности совпадали с символами, указанными в строке. During pattern matching, regular characters must exactly match the characters specified in the character string. Символы-шаблоны могут совпадать с произвольными элементами символьной строки. However, wildcard characters can be matched with arbitrary fragments of the character string. Использование символов-шаблонов в отличие от использования операторов сравнения строки (= и !=) делает оператор LIKE более гибким. Using wildcard characters makes the LIKE operator more flexible than using the = and != string comparison operators. Если тип данных одного из аргументов не является символьной строкой, компонент Компонент SQL Server Database Engine SQL Server Database Engine , если это возможно, преобразует его в тип данных символьной строки. If any one of the arguments isn’t of character string data type, the Компонент SQL Server Database Engine SQL Server Database Engine converts it to character string data type, if it’s possible.
Синтаксические обозначения в Transact-SQL Transact-SQL Syntax Conventions
Синтаксис Syntax
Аргументы Arguments
match_expression match_expression
Любое допустимое выражение expression символьного типа данных. Is any valid expression of character data type.
pattern pattern
Конкретная строка символов для поиска в match_expression может содержать следующие допустимые символы-шаблоны. Is the specific string of characters to search for in match_expression, and can include the following valid wildcard characters. Длина значения pattern не может превышать 8000 байт. pattern can be a maximum of 8,000 bytes.
Символ-шаблон Wildcard character | Описание Description | Пример Example |
---|---|---|
% | Любая строка, содержащая ноль или более символов. Any string of zero or more characters. | Инструкция WHERE Название LIKE ‘%компьютер%’ выполняет поиск и выдает все названия книг, содержащие слово «компьютер». WHERE title LIKE ‘%computer%’ finds all book titles with the word ‘computer’ anywhere in the book title. |
_ (подчеркивание) _ (underscore) | Любой одиночный символ. Any single character. | Инструкция WHERE фамилия_автора LIKE ‘_етров’ выполняет поиск и выдает все имена, состоящие из шести букв и заканчивающиеся сочетанием «етров» (Петров, Ветров и т.п.). WHERE au_fname LIKE ‘_ean’ finds all four-letter first names that end with ean (Dean, Sean, and so on). |
[ ] [ ] | Любой одиночный символ, содержащийся в диапазоне ([a-f]) или наборе ([abcdef]). Any single character within the specified range ([a-f]) or set ([abcdef]). | Инструкция WHERE Фамилия_автора LIKE ‘[Л-С]омов’ выполняет поиск и выдает все фамилии авторов, заканчивающиеся на «омов» и начинающиеся на любую букву в промежутке от «Л» до «С», например Ломов, Ромов, Сомов и т.l]%’ all author last names starting with de and where the following letter isn’t l. |
escape_character escape_character
Символ, помещаемый перед символом-шаблоном для того, чтобы символ-шаблон рассматривался как обычный символ, а не как шаблон. Is a character put in front of a wildcard character to indicate that the wildcard is interpreted as a regular character and not as a wildcard. Аргумент escape_character является символьным выражением, не имеющим значения по умолчанию и возвращающим результат в виде одного символа. escape_character is a character expression that has no default and must evaluate to only one character.
Типы результата Result Types
Boolean Boolean
Значение результата Result Value
Оператор LIKE возвращает значение TRUE, если аргумент match_expression совпадает с указанным аргументом pattern. LIKE returns TRUE if the match_expression matches the specified pattern.
При использовании оператора LIKE для сравнения строк во внимание принимаются все символы строки-шаблона. When you do string comparisons by using LIKE, all characters in the pattern string are significant. К значимым символам также относятся начальные и конечные пробелы. Significant characters include any leading or trailing spaces. Если операция сравнения в запросе должна вернуть все строки, содержащие строки LIKE ‘абв ‘ (с символом пробела на конце), то строка, содержащая «абв» (без пробела), не будет возвращена. If a comparison in a query is to return all rows with a string LIKE ‘abc ‘ (abc followed by a single space), a row in which the value of that column is abc (abc without a space) isn’t returned. Однако завершающие пробелы в выражении, с которым сравнивается шаблон, не учитываются. However, trailing blanks, in the expression to which the pattern is matched, are ignored. Если операция сравнения в запросе должна вернуть все строки, содержащие строки LIKE ‘абв’ (без знака пробела на конце), то будут возвращены все строки, содержащие «абв», как с завершающими пробелами, так и без них. If a comparison in a query is to return all rows with the string LIKE ‘abc’ (abc without a space), all rows that start with abc and have zero or more trailing blanks are returned.
При сравнении строк с помощью оператора LIKE с использованием шаблона, содержащего тип данных char и varchar, могут возникнуть проблемы из-за методов хранения каждого типа данных. A string comparison using a pattern that contains char and varchar data may not pass a LIKE comparison because of how the data is stored for each data type. В ходе выполнения следующего примера локальная переменная char передается хранимой процедуре, а затем с помощью сравнения с шаблоном выполняется поиск всех сотрудников, чьи фамилии начинаются с указанной последовательности букв. The following example passes a local char variable to a stored procedure and then uses pattern matching to find all employees whose last names start with the specified set of characters.
Выполнение процедуры FindEmployee не дает результатов, так как переменная типа char ( @EmpLName ) всегда имеет длину в 20 символов, до которой дополняется завершающими знаками пробела. In the FindEmployee procedure, no rows are returned because the char variable ( @EmpLName ) contains trailing blanks whenever the name contains fewer than 20 characters. Переменные, содержащиеся в столбце LastName , имеют тип varchar. Поэтому завершающие пробелы в них не дописываются. Because the LastName column is varchar, there are no trailing blanks. Данная процедура завершается неудачей, так как завершающие пробелы учитываются. This procedure fails because the trailing blanks are significant.
Процедура из следующего примера выполняется успешно, так как завершающие пробелы к переменной типа varchar не добавляются. However, the following example succeeds because trailing blanks aren’t added to a varchar variable.
Результирующий набор: Here is the result set.
Сопоставление шаблонов с использованием оператора LIKE Pattern Matching by Using LIKE
Оператор LIKE поддерживает сопоставление шаблонов в ASCII и Юникоде. LIKE supports ASCII pattern matching and Unicode pattern matching. Если все аргументы (match_expression, pattern и escape_character, если он указан) имеют символьный тип ASCII, то применяется шаблон ASCII. When all arguments (match_expression, pattern, and escape_character, if present) are ASCII character data types, ASCII pattern matching is performed. Если какой-либо из аргументов имеет тип данных Юникода, выполняется преобразование всех аргументов в Юникод и применяется шаблон Юникода. If any one of the arguments are of Unicode data type, all arguments are converted to Unicode and Unicode pattern matching is performed. Если вы используете оператор LIKE с типом данных Юникода (nchar или nvarchar), завершающие пробелы учитываются в отличие от других типов данных (не Юникода). When you use Unicode data (nchar or nvarchar data types) with LIKE, trailing blanks are significant; however, for non-Unicode data, trailing blanks aren’t significant. Оператор LIKE, используемый с данными Юникод, поддерживает стандарт ISO. Unicode LIKE is compatible with the ISO standard. Оператор LIKE, используемый с данными ASCII, поддерживает более ранние версии SQL Server SQL Server . ASCII LIKE is compatible with earlier versions of SQL Server SQL Server .
В следующих примерах показаны различия в строках, возвращаемых при сопоставлении шаблонов Юникода и ASCII с использованием оператора LIKE. The following is a series of examples that show the differences in rows returned between ASCII and Unicode LIKE pattern matching.
Операции сравнения с помощью оператора LIKE зависят от параметров сортировки. LIKE comparisons are affected by collation. Дополнительные сведения см. в разделе COLLATE (Transact-SQL). For more information, see COLLATE (Transact-SQL).
Использование символа-шаблона «%» Using the % Wildcard Character
Если в операторе LIKE указать символ ‘5%’, то компонент Компонент Database Engine Database Engine будет искать число «5», за которым следует любая строка с числом символов от нуля и больше. If the LIKE ‘5%’ symbol is specified, the Компонент Database Engine Database Engine searches for the number 5 followed by any string of zero or more characters.
Например, при выполнении следующего примера отображаются все динамические административные представления базы данных AdventureWorks2012 AdventureWorks2012 , так как все они начинаются символами dm . For example, the following query shows all dynamic management views in the AdventureWorks2012 AdventureWorks2012 database, because they all start with the letters dm .
Чтобы отобразить все объекты, не являющиеся динамическими административными представлениями, используется синтаксис NOT LIKE ‘dm%’ .m]%’ . Вместо 19 имен можно найти только 14, так как имена, которые начинаются с буквы d или у которых второй буквой является m , будут исключены из результата, как и имена динамических административных представлений. Instead of 19 names, you may find only 14, with all the names that start with d or have m as the second letter eliminated from the results, and the dynamic management view names. Причиной такой реакции на событие является поэтапный поиск отрицательных символов-шаблонов: за один шаг обрабатывается один символ-шаблон. This behavior is because match strings with negative wildcard characters are evaluated in steps, one wildcard at a time. Процесс поиска совпадений прекращается при возникновении сбоя на любой стадии выполнения. If the match fails at any point in the evaluation, it’s eliminated.
Использование символов-шаблонов в качестве литералов Using Wildcard Characters As Literals
Символы-шаблоны могут быть использованы в качестве литералов. You can use the wildcard pattern matching characters as literal characters. Чтобы использовать символ-шаблон в качестве литерала, его необходимо заключать в скобки. To use a wildcard character as a literal character, enclose the wildcard character in brackets. В следующей таблице представлены несколько примеров применения ключевого слова LIKE вместе с символами-шаблонами [ ]. The following table shows several examples of using the LIKE keyword and the [ ] wildcard characters.
Символ Symbol | Значение Meaning |
---|---|
LIKE ‘5[%]’ LIKE ‘5[%]’ | 5 % 5% |
LIKE ‘[]n’ LIKE ‘[]n’ | _n _n |
LIKE ‘[a-cdf]’ LIKE ‘[a-cdf]’ | a, b, c, d или f a, b, c, d, or f |
LIKE ‘[-acdf]’ LIKE ‘[-acdf]’ | -, a, b, c, d или f -, a, c, d, or f |
LIKE ‘[ [ ]’ LIKE ‘[ [ ]’ | [ [ |
LIKE ‘]’ LIKE ‘]’ | ] ] |
LIKE ‘abc[]d%’ LIKE ‘abc[]d%’ | abc_d и abc_de abc_d and abc_de |
LIKE ‘abc[def]’ LIKE ‘abc[def]’ | abcd, abce и abcf abcd, abce, and abcf |
Совпадение с шаблоном с помощью предложения ESCAPE Pattern Matching with the ESCAPE Clause
Можно искать символьные строки, в состав которых входит один или более специальных символов-шаблонов. You can search for character strings that include one or more of the special wildcard characters. Например, таблица discounts базы данных customers может содержать значения скидок, включающих знак процента (%). For example, the discounts table in a customers database may store discount values that include a percent sign (%). Чтобы выполнить поиск знака процента в качестве символа-шаблона, необходимо ввести ключевое слово ESCAPE и escape-символ. To search for the percent sign as a character instead of as a wildcard character, the ESCAPE keyword and escape character must be provided. Например, образец базы данных содержит столбец с именем comment, в котором хранится значение «30%». For example, a sample database contains a column named comment that contains the text 30%. Чтобы найти строки, содержащие последовательность символов «30%» в столбце comment, необходимо указать предложение WHERE, например WHERE comment LIKE ‘%30!%%’ ESCAPE ‘!’ . To search for any rows that contain the string 30% anywhere in the comment column, specify a WHERE clause such as WHERE comment LIKE ‘%30!%%’ ESCAPE ‘!’ . Если предложение ESCAPE и escape-символ не указаны, компонент Компонент Database Engine Database Engine вернет все записи, содержащие последовательность символов «30!». If ESCAPE and the escape character aren’t specified, the Компонент Database Engine Database Engine returns any rows with the string 30!.
Если в шаблоне LIKE после escape-символа нет никакого символа, то шаблон является недопустимым и оператор LIKE возвращает значение FALSE. If there is no character after an escape character in the LIKE pattern, the pattern isn’t valid and the LIKE returns FALSE. Если символ после escape-символа не является символом-шаблоном, то escape-символ игнорируется, а следующий символ рассматривается как обычный символ в шаблоне. If the character after an escape character isn’t a wildcard character, the escape character is discarded and the following character is treated as a regular character in the pattern. К этим символам-шаблонам относятся: подчеркивание (), процент (%) и левая квадратная скобка ([), в том случае, если они заключены в квадратные скобки.), hyphen (-), or right bracket (]).
Символ 0x0000 (char(0)) не определен в параметрах сортировки Windows, и его нельзя включать в LIKE. 0x0000 (char(0)) is an undefined character in Windows collations and can’t be included in LIKE.
Примеры Examples
A. A. Применение оператора LIKE с символом-шаблоном % Using LIKE with the % wildcard character
В следующем примере в таблице 415 выполняется поиск всех телефонных номеров с кодом города PersonPhone . The following example finds all telephone numbers that have area code 415 in the PersonPhone table.
Результирующий набор: Here is the result set.
Результирующий набор: Here is the result set.
Г. D. Использование символов-шаблонов [ ] Using the [ ] wildcard characters
В следующем примере выполняется поиск в таблице Person сотрудников с именем Cheryl или Sheryl . The following example finds employees on the Person table with the first name of Cheryl or Sheryl .
В следующем примере выполняется поиск строк в таблице Person для сотрудников с фамилией Zheng или Zhang . The following example finds the rows for employees in the Person table with last names of Zheng or Zhang .
Примеры: Azure Synapse Analytics (хранилище данных SQL) Azure Synapse Analytics (SQL DW) и Параллельное хранилище данных Parallel Data Warehouse Examples: Azure Synapse Analytics (хранилище данных SQL) Azure Synapse Analytics (SQL DW) and Параллельное хранилище данных Parallel Data Warehouse
Д. E. Применение оператора LIKE с символом-шаблоном % Using LIKE with the % wildcard character
В следующем примере в таблице DimEmployee выполняется поиск всех сотрудников, телефонные номера которых начинаются с 612 . The following example finds all employees in the DimEmployee table with telephone numbers that start with 612 .
Е. F. Применение оператора NOT LIKE с символом-шаблоном % Using NOT LIKE with the % wildcard character
В следующем примере в таблице DimEmployee выполняется поиск всех телефонных номеров, которые не начинаются с 612 . The following example finds all telephone numbers in the DimEmployee table that don’t start with 612 . . .
Ж. G. Применение оператора LIKE с символом-шаблоном _ Using LIKE with the _ wildcard character
В следующем примере в таблице DimEmployee выполняется поиск всех телефонных номеров, начинающихся с 2 и заканчивающихся на 6 . The following example finds all telephone numbers that have an area code starting with 6 and ending in 2 in the DimEmployee table. Подстановочный знак «%» добавлен в конце шаблона поиска, что соответствует любым следующим символам в значениях столбца с телефонными номерами. The % wildcard character is included at the end of the search pattern to match all following characters in the phone column value.
Оператор LIKE в SQL
Оператор LIKE применяется только к полям типа CHAR и VARCHAR, поскольку он используется для поиска подстрок. Другими словами, оператор LIKE осуществляет просмотр строки для выяснения: входит ли заданная подстрока в указанное поле. Для осуществления более качественного просмотра подстроки используются шаблоны. Шаблоны – это специальные символы, которые могут обозначать всё что угодно.
Шаблоны оператора LIKE для поиска
- Существует три типа шаблонов, которые можно использовать с оператором LIKE:
- Символ «нижнее подчёркивание» (_) заменяет один любой символ.
- Символ «процент» (%) заменяет последовательность символов произвольной длины, в том числе и нулевой.
- Квадратные скобки [ ], внутри них можно указать последовательность символов, чтобы выполнить поиск. Если мы укажем в квадратных скобках последовательность символов, например — ВИ, то поиск будет выполняться с учётом того, что информация будет начинаться с В или И.
Escape-символы (экранирование символов)
Чтобы найти в строке символ подчёркивания или процента, в предикате LIKE любой символ можно определить, как Escape-символ. Он используется в предикате непосредственно перед символом процента или подчёркивания, и означает что следующий за ним символ интерпретируется именно как обычный символ, а не как символ шаблона.ВИ]%’;
Метки: LIKE, SQL.
MySQL LIKE.
Оператор MySQL LIKE используется в SQL-запросах в условии WHERE для поиска ячеек в столбце (или нескольких столбцах) по определенному паттерну.
Синтаксис MySQL LIKE.
1 2 3 | SELECT column_name FROM table_name WHERE column_name LIKE pattern |
Допустим у нас есть таблица с пользователями.
Нам необходимо извлечь всех пользователей из таблицы, название города которых начинается с буквы ‘s’.
Для этого мы можем использовать такой запрос:
1 2 | SELECT * FROM Persons WHERE City LIKE 's%' |
Символ ‘%’, идущий более буквы ‘s’ означает, что мы ищем строку, начинающуюся на ‘s’ (после нее может быть один или несколько символов, а может и не быть ничего).
Запрос, описанный выше вернет всю нашу таблицу.
Теперь мы хотим получить выборку всех пользователей, город которых заканчивается на букву ‘s’. Для этого символ ‘%’ мы поставим перед буквой ‘s’.
1 2 | SELECT * FROM Persons WHERE City LIKE '%s' |
Данный запрос вернет нам результат, состоящий только из двух строк:
Противоположным данному оператору является оператор с отрицанием NOT LIKE. К примеру, нам необходимо извлечь все строки, где название города не содержит слога ‘tav’. Запрос будет таким:
1 2 | SELECT * FROM Persons WHERE City NOT LIKE '%tav%' |
Мы получим следующий результат:
Другие посты
Категория: MySQL
Как искать слэш (\) в MySQL? и почему escaping (\) не требуется для where (=), но для Like требуется?
Почему не требуется дополнительное (\) для (=), но для (как) дополнительного \\ требуется? Ясно, что MySQL ускользнул от (test \) с помощью (test \\), после чего использование (test \\\\) логично для LIKE.
\
выполняет функцию escape-символа в LIKE
по умолчанию.
Из руководства для LIKE
:
Поскольку MySQL использует синтаксис C escape в строках (например, «\ n» для представления символа новой строки), вы должны удвоить любой «\», который вы используете в строках LIKE. Например, для поиска «\ n» укажите его как «\\ n». Чтобы найти «\», укажите его как «\\\\»; это происходит из-за того, что обратная косая черта разделяется один раз парсером и снова, когда выполняется совпадение с шаблоном , оставляя единственную обратную косую черту, которая должна быть сопоставлена.
Вы можете изменить это, указав другой escape-символ, как в:
SELECT * FROM `titles` where title LIKE 'test\\' ESCAPE '|'
На самом деле все предыдущие ответы были искажены где-то. Как вы можете видеть в ссылке, предоставленной Karoly Horvath, чей значительный бит воспроизводится Explosion Pills, правильный способ поиска 1 обратной косой черты (\) состоит в том, чтобы использовать сразу 4 обратных слэша (\\\\) .
Кстати, чтобы показать выше, что одна обратная косая черта мне пришлось использовать сразу два, и чтобы показать эти четыре, мне пришлось использовать восемь.
LIKE
принимает два символа wildchar, %
и _
.
Чтобы соответствовать этим символам, можно использовать экранирование: \%
, \_
. Это также означает, что если вы хотите сопоставить \
, он также должен быть экранирован.
Все это описано в руководстве .
Для нахождения \
в текстовом поле мне пришлось избегать \
дважды, иначе был найден %
в конце:
SELECT * FROM `table` where `field` LIKE '%\\\%';
Проверка нескольких условий (операторы OR и AND)
Вывести данные о всех клиентах, проживающих в Сиэтле и только о тех клиентах из Лос-Анджелеса, численность семьи которых превышает 3-х человек.
SQL:
SELECT lastname, name, region, fam_size
FROM tbl_clients
WHERE region= ‘Seattle’ OR region = ‘Los Angeles’ AND fam_size>3
Результат:
lastname | name | region | fam_size |
Stolz | Barbara | Seattle | 6 |
Abbott | Thomas | Seattle | 2 |
Vaughn | Jeffrey | Seattle | 2 |
Sperber | Gregory | Seattle | 3 |
Org | Liina | Los Angeles | 4 |
Reynolds | Christian | Los Angeles | 5 |
Salinas | Danny | Los Angeles | 5 |
Miller | Robert | Los Angeles | 4 |
Ausmees | Ingrid | Seattle | 6 |
Clark | Margaret | Los Angeles | 4 |
Philbrick | Penny | Seattle | 1 |
…. | ….. | ….. |
… |
Ограничение на количество членов семьи в предыдущем запросе применяется только к клиентам из Лос-Анджелеса, так как оператор AND выполняется перед оператором OR. Чтобы первым выполнялся оператор OR, в запросе нужно использовать скобки.
В результате выполнения следующего запроса будут данные о всех клиентах из Сиэтла и Лос-Анджелеса, имеющих семьи численностью больше 3 человек:
SQL:
SELECT lastname, name, region, fam_size
FROM tbl_clients
WHERE (region= ‘Seattle’ OR region = ‘Los Angeles’) AND
fam_size>3
Запрос данных на основе указанного шаблона
Сводка : В этом руководстве вы узнаете, как использовать оператор MySQL LIKE
для запроса данных на основе указанного шаблона.
Введение в MySQL оператор LIKE
Оператор LIKE
— это логический оператор, который проверяет, содержит ли строка указанный шаблон или нет.
Вот синтаксис оператора LIKE
:
Язык кода: SQL (язык структурированных запросов) (sql)
шаблон выражения LIKE ESCAPE escape_character
В этом синтаксисе, если выражение
соответствует шаблон
, оператор LIKE
возвращает 1.В противном случае он возвращает 0.
MySQL предоставляет два подстановочных символа для построения шаблонов: процент %
и подчеркивание _
.
- Подстановочный знак в процентах (
%
) соответствует любой строке из нуля или более символов. - Подстановочный знак подчеркивания (
_
) соответствует любому одиночному символу.
Например, s%
соответствует любой строке, начинающейся с символа s
, например sun
и six
. se_
соответствует любой строке, начинающейся с se
, за которой следует любой символ, например see
и sea
.
Если шаблон содержит подстановочный знак и вы хотите рассматривать его как обычный символ, вы можете использовать предложение ESCAPE
.
Обычно вы используете оператор LIKE
в предложении WHERE
операторов SELECT
, DELETE
и UPDATE
.
MySQL, примеры оператора LIKE
Давайте попрактикуемся с некоторыми примерами использования оператора LIKE
.Мы будем использовать следующую таблицу сотрудников
из образца базы данных для демонстрации:
A) Использование оператора MySQL LIKE с подстановочными знаками процента (%)
В этом примере используется оператор LIKE
для поиска сотрудников, чьи имена начинаются с буквой а
:
Язык кода: SQL (язык структурированных запросов) (sql)
ВЫБРАТЬ номер сотрудника, фамилия, имя ИЗ сотрудники КУДА firstName КАК 'a%';
Попробовать
В этом примере MySQL сканирует всю таблицу
сотрудников
, чтобы найти сотрудников, имена которых начинаются с буквы a
и являются за которым следует любое количество символов. В этом примере оператор LIKE
используется для поиска сотрудников, чьи фамилии заканчиваются буквальной строкой на
, например, Patterson
, Thompson
:
Язык кода: SQL (язык структурированных запросов) (sql)
SELECT номер сотрудника, фамилия, имя ИЗ сотрудники КУДА lastName LIKE '% on';
Попробовать
Чтобы проверить, содержит ли строка подстроку, вы можете использовать подстановочный знак процента (%
) в начале и в конце подстрока.
Например, следующий запрос использует оператор LIKE
для поиска всех сотрудников, чьи фамилии содержат подстроку на
:
Язык кода: SQL (язык структурированных запросов) (sql)
SELECT номер сотрудника, фамилия, имя ИЗ сотрудники КУДА фамилия LIKE '% on%';
Попробовать
B) Использование оператора MySQL LIKE с символом подчеркивания (
_
) Примеры подстановочных знаков Чтобы найти сотрудников, имена которых начинаются с буквы T
, заканчиваться буквой m
и содержать любой одиночный символ между e.g., Tom
, Tim
, используйте подстановочный знак подчеркивания (_) для создания шаблона следующим образом:
Язык кода: SQL (язык структурированных запросов) (sql)
SELECT номер сотрудника, фамилия, имя ИЗ сотрудники КУДА имя LIKE 'T_m';
Попробовать
C) Пример использования оператора MySQL NOT LIKE
MySQL позволяет комбинировать оператор NOT
с оператором LIKE
чтобы найти строку, не соответствующую определенному шаблону.
Предположим, вы хотите найти сотрудников, чьи фамилии не начинаются с буквы B
, вы можете использовать оператор NOT LIKE
следующим образом:
Язык кода: SQL (язык структурированных запросов) (sql)
SELECT номер сотрудника, фамилия, имя ИЗ сотрудники КУДА lastName НЕ НРАВИТСЯ 'B%';
Попробовать
Обратите внимание, что в шаблоне регистр не учитывается. Следовательно, шаблоны b%
и B%
возвращают одинаковый результат.
MySQL оператор LIKE с предложением ESCAPE
Иногда шаблон может содержать символы подстановки, например, 10%, _20 и т. Д.
В этом случае вы можете использовать предложение ESCAPE
, чтобы указать escape-символ, чтобы Оператор LIKE интерпретирует подстановочный знак как буквальный символ.
Если вы не укажете escape-символ явно, обратная косая черта ( \
) будет escape-символом по умолчанию.
Например, если вы хотите найти продукты, коды продуктов которых содержат строку _20
, вы можете использовать шаблон % \ _ 20%
с escape-символом по умолчанию:
Язык кода: SQL (язык структурированных запросов) (sql)
SELECT код продукта, наименование товара ИЗ продукты КУДА productCode LIKE '% \ _ 20%';
Попробовать
В качестве альтернативы вы можете указать другой escape-символ e.g., $
с использованием предложения ESCAPE
:
Язык кода: SQL (язык структурированных запросов) (sql)
SELECT код продукта, наименование товара ИЗ продукты КУДА productCode LIKE '% $ _ 20%' ESCAPE '$';
Попробовать
Шаблон % $ _ 20%
соответствует любой строке, содержащей строку _20
.
Сводка
- Используйте оператор
LIKE
, чтобы проверить, соответствует ли значение шаблону. - Подстановочный знак
%
соответствует нулю или более символам. - Подстановочный знак
_
соответствует одному символу. - Использование
ESCAPE Предложение
определяет escape-символ, отличный от escape-символа по умолчанию (\
). - Используйте оператор
NOT
, чтобы отрицать операторLIKE
.
Было ли это руководство полезным?
MySQL: условие LIKE
Это учебное пособие по MySQL объясняет, как использовать MySQL LIKE condition для выполнения сопоставления с образцом с синтаксисом и примерами.
Синтаксис
Синтаксис условия LIKE в MySQL:
выражение LIKE pattern [ESCAPE 'escape_character']
Параметры или аргументы
- выражение
- Символьное выражение, например столбец или поле.
- узор
Символьное выражение, содержащее сопоставление с образцом. Вы можете выбрать из следующих паттернов:
Подстановочный знак Пояснение % Позволяет сопоставить любую строку любой длины (включая нулевую) _ Позволяет сопоставить один символ - escape_character
- Необязательно.Это позволяет вам проверять буквальные экземпляры подстановочного символа, такого как% или _. Если вы не предоставите escape_character , MySQL предполагает, что «\» — это escape_character .
Пример — использование подстановочного знака% (подстановочный знак процента)
Первый пример MySQL LIKE, который мы рассмотрим, включает использование подстановочного знака% (подстановочный знак процента).
Давайте объясним, как подстановочный знак% работает в MySQL условии LIKE. Мы хотим найти всех клиентов, у которых last_name начинается с Sm.
ВЫБЕРИТЕ имя_клиента ОТ клиентов ГДЕ last_name КАК 'Sm%';
Вы также можете использовать подстановочный знак% несколько раз в одной строке. Например,
ВЫБЕРИТЕ имя_клиента ОТ клиентов ГДЕ last_name LIKE '% it%';
В этом примере условия MySQL LIKE мы ищем всех клиентов , чье last_name содержит символы «оно».
Пример — использование подстановочного знака _ (подстановочный знак подчеркивания)
Теперь давайте объясним, как подстановочный знак _ (подстановочный знак подчеркивания) работает в MySQL условии LIKE.Помните, что подстановочный знак _ ищет только один символ.
Например:
ВЫБРАТЬ имя_поставщика ОТ поставщиков ГДЕ имя_поставщика НРАВИТСЯ 'Sm_th';
Этот пример условия MySQL LIKE вернет всех поставщиков, чье имя_поставщика имеет длину 5 символов, где первые два символа — это «Sm», а последние два символа — «th». Например, он может возвращать поставщиков, чье имя_поставщика — «Smith», «Smyth», «Smath», «Smeth» и т. Д.
Вот еще один пример:
ВЫБРАТЬ * ОТ поставщиков ГДЕ account_number КАК '12345_';
Вы можете обнаружить, что ищете номер счета, но у вас есть только 5 из 6 цифр. В приведенном выше примере будет получено потенциально 10 записей обратно (где отсутствующее значение может быть от 0 до 9). Например, он может возвращать поставщиков с номерами счетов:
.123450, 123451, 123452, 123453, 123454, 123455, 123456, 123457, 123458, 123459
Пример — использование оператора НЕ
Далее давайте посмотрим, как можно использовать оператор NOT с подстановочными знаками.
Давайте использовать% wilcard с оператором NOT. Вы также можете использовать условие MySQL LIKE для поиска поставщиков, чье имя , а не начинается с ‘G’.
Например:
ВЫБРАТЬ имя_поставщика ОТ поставщиков ГДЕ имя_поставщика НЕ НРАВИТСЯ на 'G%';
Поместив оператор NOT перед условием MySQL LIKE, вы можете получить всех поставщиков, у которых имя_поставщика не , а начинается с ‘G’.
Пример — использование escape-символов
Важно понимать, как «экранировать символы» при сопоставлении с образцом.Эти примеры конкретно относятся к экранированию символов в MySQL.
Допустим, вы хотели найти символ% или _ в условии MySQL LIKE. Вы можете сделать это с помощью символа Escape.
Обратите внимание, что вы можете определить escape-символ только как одиночный символ (длина 1).
Например:
ВЫБРАТЬ * ОТ поставщиков ГДЕ имя_поставщика LIKE 'G \%';
Поскольку мы не указали escape-символ, MySQL предполагает, что «\» является escape-символом.Затем MySQL предполагает, что escape-символом является «\», что приводит к тому, что MySQL обрабатывает символ% как литерал, а не подстановочный знак. Этот оператор затем вернет всех поставщиков , чье имя_поставщика равно G%.
Мы можем переопределить escape-символ по умолчанию в MySQL, указав модификатор ESCAPE следующим образом:
ВЫБРАТЬ * ОТ поставщиков ГДЕ имя_поставщика LIKE 'G!%' ESCAPE '!';
Этот пример условия MySQL LIKE определяет! символ как escape-символ.! escape-символ приведет к тому, что MySQL будет рассматривать символ% как литерал. В результате этот оператор также вернет всех поставщиков, у которых имя_поставщика равно G%.
Вот еще один более сложный пример использования escape-символов в MySQL условии LIKE.
ВЫБРАТЬ * ОТ поставщиков ГДЕ имя_поставщика LIKE 'H% \%';
Этот пример условия MySQL LIKE возвращает всех поставщиков , имя которых начинается с H и заканчивается на%. Например, он вернет такое значение, как «Hello%».Поскольку мы не указали escape-символ в условии LIKE, MySQL предполагает, что escape-символ равен «\», что приводит к тому, что MySQL обрабатывает второй символ% как литерал, а не подстановочный знак.
Мы можем изменить это условие LIKE, указав escape-символ следующим образом:
ВЫБРАТЬ * ОТ поставщиков ГДЕ имя_поставщика LIKE 'H%!%' ESCAPE '!';
Этот пример условия MySQL LIKE возвращает всех поставщиков, чьи имена начинаются с H и заканчиваются литералом%.Например, он вернет такое значение, как «Hello%».
Вы также можете использовать escape-символ с символом _ в условии MySQL LIKE.
Например:
ВЫБРАТЬ * ОТ поставщиков ГДЕ имя_поставщика LIKE 'H% \ _';
Опять же, поскольку модификатор ESCAPE не предоставляется, MySQL использует «\» в качестве escape-символа, в результате чего символ _ обрабатывается как литерал вместо подстановочного знака. Затем в этом примере будут возвращены все поставщики, у которых имя_поставщика начинается с H и заканчивается на _.Например, он вернет такое значение, как «Hello_».
Нравится, НЕ нравится, Побег, (%), (_)
Что такое подстановочные знаки MySQL?
Подстановочные знаки MySQL — это символы, которые помогают искать данные, соответствующие сложным критериям. Подстановочные знаки используются вместе с оператором сравнения LIKE или оператором сравнения NOT LIKE.
Зачем использовать подстановочные знаки?
Если вы знакомы с использованием SQL, вы можете подумать, что можете искать любые сложные данные, используя предложения SELECT и WHERE.Тогда зачем использовать подстановочные знаки?
Прежде чем мы ответим на этот вопрос, давайте рассмотрим пример. Предположим, что отдел маркетинга видеотеки Myflix проводил маркетинговые акции в городе Техас и хотел бы получить отзывы о количестве участников
, зарегистрированный из Техаса, вы можете использовать следующий оператор SELECT вместе с предложением WHERE, чтобы получить желаемую информацию.
SELECT * FROM members WHERE postal_address = 'Austin, TX' OR postal_address = Даллас, TX OR postal_address = Iola, TX OR postal_address = Houston, TX ';
Как видно из приведенного выше запроса, «предложение WHERE» становится сложным.Однако использование подстановочных знаков упрощает запрос, поскольку мы можем использовать что-то простое, например, сценарий, показанный ниже.
SELECT * FROM members WHERE postal_address, например "% TX";
Короче говоря, подстановочные знаки позволяют нам внедрять мощные поисковые системы в наши приложения, управляемые данными.
Типы подстановочных знаков
% процент
% символ процента используется для указания шаблона из нуля (0) или более символов . Он имеет следующий базовый синтаксис.
инструкции SELECT ... WHERE fieldname LIKE 'xxx%';
ЗДЕСЬ
- «Оператор SELECT…» — это стандартная команда SQL SELECT.
- «ГДЕ» — ключевое слово, используемое для применения фильтра.
- «LIKE» — это оператор сравнения, который используется вместе с подстановочными знаками .
- «Xxx» — это любой указанный начальный образец, например, один или несколько символов, а «%» соответствует любому количеству символов, начиная с нуля (0).
Чтобы полностью оценить вышеприведенное утверждение, давайте рассмотрим практический пример
Предположим, мы хотим получить все фильмы, в названии которых есть слово «код», мы бы использовали подстановочный знак процента, чтобы выполнить сопоставление с образцом с обеих сторон слова «код».Ниже приведен оператор SQL, который можно использовать для достижения желаемых результатов.
ВЫБРАТЬ * ИЗ фильмов, ГДЕ название LIKE '% code%';
Выполнение вышеуказанного сценария в рабочей среде MySQL для myflixdb дает нам результаты, показанные ниже.
movie_id | название | директор | год_выпуска | category_id |
---|---|---|---|---|
4 | Кодовое название Черный | Эдгар Джимц | 2010 | ПУСТО |
7 | Код Давинчи | ПУСТО | ПУСТО | 6 |
Обратите внимание, что даже если ключевое слово поиска «код» появляется в начале или конце заголовка, оно все равно возвращается в нашем наборе результатов.Это потому, что наш код включает в себя любое количество символов в начале, а затем соответствует шаблону «код», за которым следует любое количество символов в конце.
Давайте теперь изменим наш приведенный выше скрипт, включив подстановочный знак процента только в начало критерия поиска.
ВЫБЕРИТЕ * ИЗ фильмов, ГДЕ название LIKE '% code';
Выполнение вышеуказанного сценария в рабочей среде MySQL для myflixdb дает нам результаты, показанные ниже.
movie_id | название | директор | год_выпуска | category_id |
---|---|---|---|---|
7 | Код Давинчи | ПУСТО | ПУСТО | 6 |
Обратите внимание, что из базы данных была возвращена только одна запись.Это потому, что наш код соответствует любому количеству символов в начале названия фильма и получает только записи, которые заканчиваются шаблоном «код».
Давайте теперь сдвинем подстановочный знак процента в конец указанного шаблона, который необходимо сопоставить. Измененный сценарий показан ниже.
ВЫБРАТЬ * ИЗ фильмов, ГДЕ название LIKE 'code%';
Выполнение вышеуказанного сценария в рабочей среде MySQL для myflixdb дает нам результаты, показанные ниже.
movie_id | название | директор | год_выпуска | category_id |
---|---|---|---|---|
4 | Кодовое название Черный | Эдгар Джимц | 2010 | ПУСТО |
Обратите внимание, что из базы данных была возвращена только одна запись.Это потому, что наш код соответствует всем заголовкам, которые начинаются с шаблона «код», за которым следует любое количество символов.
_ подстановочный знак подчеркивания
Подстановочный знак подчеркивания используется для , совпадающего точно с одним символом . Предположим, мы хотим найти все фильмы, которые были выпущены в 200x годах, где x — это ровно один символ, который может иметь любое значение. Для этого мы будем использовать подстановочный знак подчеркивания. В приведенном ниже сценарии выбираются все фильмы, выпущенные в «200x»
году.ВЫБРАТЬ * ИЗ фильмов, ГДЕ year_released LIKE '200_';
Выполнение вышеуказанного сценария в рабочей среде MySQL для myflixdb дает нам результаты, показанные ниже.
movie_id | название | директор | год_выпуска | category_id |
---|---|---|---|---|
2 | Забыть Сару Маршал | Николас Столлер | 2008 | 2 |
9 | Медовые луны | Джон Шульц | 2005 | 8 |
Обратите внимание, что в наш набор результатов были возвращены только фильмы, у которых есть 200 подписок любым персонажем в поле года выпуска.Это связано с тем, что подстановочный знак подчеркивания соответствует шаблону 200, за которым следует любой одиночный символ
НЕ нравится
Логический оператор NOT может использоваться вместе с подстановочными знаками для возврата строк, не соответствующих указанному шаблону.
Предположим, мы хотим получить фильмы, которые не были выпущены в 200x году. Мы бы использовали логический оператор NOT вместе с подстановочным знаком подчеркивания, чтобы получить наши результаты. Ниже приведен сценарий, который это делает.
ВЫБРАТЬ * ИЗ фильмов, ГДЕ year_released НЕ КАК '200_';
movie_id | название | директор | год_выпуска | category_id |
---|---|---|---|---|
1 | Пираты Карибского моря 4 | Роб Маршалл | 2011 | 1 |
4 | Кодовое название Черный | Эдгар Джимц | 2010 | ПУСТО |
8 | Пробуждение Преисподней | Майкл Ил | 2012 | 6 |
Обратите внимание, что в наш набор результатов были возвращены только фильмы, которые не начинаются с 200 в году выпуска.Это потому, что мы использовали логический оператор NOT при поиске по шаблону подстановки.
Ключевое слово Escape.
Ключевое слово ESCAPE используется для символов соответствия шаблону , таких как процент (%) и подчеркивание (_), если они составляют часть данных.
Предположим, мы хотим проверить строку «67%», которую мы можем использовать;
Если мы хотим найти фильм «67% виновных», мы можем использовать для этого сценарий, показанный ниже.
ВЫБРАТЬ * ИЗ фильмов, ГДЕ название LIKE '67 # %% 'ESCAPE' # ';
Обратите внимание на двойное «% %» в предложении LIKE, первое красное «% » рассматривается как часть искомой строки.Другой используется для соответствия любому количеству следующих символов.
Тот же запрос будет работать, если мы используем что-то вроде
ВЫБРАТЬ * ИЗ фильмов, ГДЕ название LIKE '67 = %% 'ESCAPE' = ';
Резюме
- Like & Wildcards — мощные инструменты, которые помогают искать данные по сложным шаблонам.
- Существует ряд подстановочных знаков, которые включают в себя процент, подчеркивание и список символов (не поддерживаются MySQL) среди других
- Подстановочный знак процента используется для соответствия любому количеству символов, начиная с нуля (0) и более.
- Подстановочный знак подчеркивания используется для соответствия ровно одному символу.
Оператор MySQL LIKE
Оператор MySQL LIKE используется для выполнения произвольного поиска в таблицах. Оператор MYSQL Like использует подстановочные знаки для извлечения записей, соответствующих указанному шаблону.
Например, если вы забыли написание или описание продукта, используйте подстановочный знак оператора LIKE в MySQL, чтобы найти совпадающие записи. Ниже приведены поддерживающие подстановочные знаки в MySQL
Подстановочные знаки MySQL | Описание | ||
---|---|---|---|
% | Используйте это, чтобы сопоставить ноль или более символов | ||
_ | Используйте это, чтобы точно сопоставить один символ |
Образец | Значение |
---|---|
‘a%’ | Соответствующие строки, начинающиеся с ‘a’ |
‘% a ‘ | Соответствует строкам с концом на’ a ‘ |
‘ a% t ‘ | Соответствует строкам, которые начинаются с’ a ‘и заканчиваются’ t ‘. |
‘% wow%’ | Соответствующие строки, которые содержат подстроку ‘wow’ в любой позиции. |
‘_wow%’ | Соответствующие строки, которые содержат подстроку ‘wow’ во второй позиции. |
‘_a%’ | Соответствующие строки, содержащие «a» во второй позиции. |
‘a_ _%’ | Соответствующие строки, которые начинаются с ‘a’ и содержат как минимум 2 дополнительных символа. |
Чтобы использовать операции LIKE, мы будем использовать следующую таблицу:
Ниже приведены различные примеры использования оператора LIKE в Python MySQL.
Пример 1:
Программа для отображения строк, адрес которых начинается с буквы G в таблице itdept.
Python3
« |
Вывод:
Пример 2:
Здесь мы отображаем все строки, в которых имя начинается с буквы H и заканчивается буквой A в таблице.
Python3
« |
Вывод:
Пример 3:
В этой программе мы отображаем все строки с трехбуквенными адресатами в таблице.
Python3
« |
Выход:
Запрос SQL LIKE для сопоставления записей шаблона с таблицей MySQL с подстановочными знаками
Используя запрос LIKE, мы можем сопоставить часть полных данных, представленных в столбце. Здесь поисковое слово не обязательно должно точно совпадать.Используя Like Query с подстановочными знаками в различных комбинациях, мы можем сопоставить наше ключевое слово с шаблоном данных, представленных в столбцах.
Лучший способ использовать команду LIKE - применить ее к текстовому полю или полю varchar вместе с подстановочным знаком % или _
Упражнение с решением для запросов LIKE
Видеоурок по запросу LIKE с комбинациями И, ИЛИ НЕ.
.
Вот наша таблица со всеми записями.
id | наименование | класс | марка |
---|---|---|---|
1 | Джон Део | Четыре | 75 |
2 | Макс Руин | Три | 85 |
3 | Арнольд | Три | 55 |
4 | Krish Star | Четыре | 60 |
5 | Джон Майк | Четыре | 60 |
6 | Алекс Джон | Четыре | 55 |
Здесь мы применим команду LIKE к нашему полю имени.
ВЫБРАТЬ * ОТ ученика ГДЕ имя LIKE '% John%'
id | название | класс | марка |
---|---|---|---|
1 | Джон Deo | Четыре | 75 |
5 | Джон Майк | Четыре | 60 |
6 | Алексей Иоанн | Четыре | 55 |
Прочтите, как регулярное выражение используется для сопоставления с образцом
ВЫБРАТЬ * ОТ ученика ГДЕ имя КАК "Джон%"
id | название | класс | марка |
---|---|---|---|
1 | Джон Deo | Четыре | 75 |
5 | Джон Майк | Четыре | 60 |
ВЫБРАТЬ * ОТ ученика ГДЕ имя КАК "% Джон"
id | название | class | mark |
---|---|---|---|
6 | Алексей Иоанн | Четыре | 55 |
В приведенном выше результате желаемое слово John находится только в конце.
Соответствующая строка в столбце имени, начиная с A и заканчивая n .
ВЫБРАТЬ * ОТ ученика ГДЕ имя КАК 'A% n'
Выход 6 Алекс Джон Четыре 55 кобель
Вот сводка сопоставления строк с использованием% вместе с запросом LIKE '% John' | Соответствует строке, заканчивающейся на John |
'John%' | Соответствует строке, начинающейся с John |
'% John% Соответствует строке в любом месте с John | |
'j% n' | Соответствует строке, начинающейся с j и заканчивающейся n |
Использование символа подчеркивания (_) в качестве символа подстановки в сопоставлении строки
Мы можем использовать подчеркивание как подстановочный знак для одного пробела и использовать его вместе с оператором LIKE и применять его к столбцам таблицы.Например, мы хотим собрать все номера счетов, заканчивающиеся на 044, в поле с пятизначным номером счета. Вот запрос для этого. ВЫБРАТЬ * ОТ account_master ГДЕ acc_no LIKE '__044'
В нашем запросе мы использовали два символа подчеркивания, чтобы указать, что первые две цифры могут быть любыми и должны заканчиваться на 044.Подчеркивание как подстановочный знак можно использовать в любом месте, но можно заменить только один символ. Мы также можем использовать более одного подчеркивания внутри нашего запроса.
Использование NOT с LIKE
ВЫБРАТЬ * ОТ ученика, ГДЕ имя НЕ КАК "% John%"
Таким образом, мы можем использовать команду LIKE со многими другими командами для получения желаемого результата.Запрос с учетом регистра
Как мы видели, во всех приведенных выше случаях регистр не учитывается. Чтобы соответствовать только нижнему или только верхнему регистру, мы должны использовать двоичную команду для выполнения двоичного сопоставления. Вот пример. выберите * от студента, где имя LIKE binary '% A'
Попробуйте выполнить тот же запрос, не используя в нем двоичный файл.Фамилия учеников, имеющая букву «а» и букву «е» (без одинарных кавычек)
ВЫБЕРИТЕ * ОТ ученика, ГДЕ имя КАК '% a%' И имя КАК '% e%'
Найдите в таблице разделов все курсы, которые начинаются с символа C , но не имеют второго символа h . ВЫБРАТЬ * ОТ ученика, ГДЕ имя КАК 'C%' И имя НЕ КАК '_h%'
Поиск ключевого слова в нескольких столбцах с использованием И, ИЛИ
Ключевое слово должно присутствовать в обоих столбцах (с помощью AND) ВЫБРАТЬ * ИЗ TABLE_NAME
ГДЕ Column1, как "% keyword%" И Column2, как "% keyword%"
Ключевое слово должно присутствовать в любых столбцах (с помощью ИЛИ) ВЫБРАТЬ * ИЗ TABLE_NAME
ГДЕ Column1 Like '% keyword%' ИЛИ Column2 LIKE '% keyword%'
Таким же образом запрос можно расширить для поиска по более чем двум столбцам.КАК с CONCAT
В предоставленной строке совпадает имя. (Обратный способ сопоставления) ВЫБРАТЬ * ОТ ученика ГДЕ
«Наш лучший ученик - мистер Джон Део из 5-го класса»
LIKE CONCAT ('%', имя, '%')
CONCAT для соединения строк в запросе
Ограничение запроса Like
Подобное условие должно соответствовать всем данным, тогда как, используя регулярное выражение REGEXP, мы можем сопоставить любое место в данныхОтображение записей с использованием PHP-скрипта
Все вышеперечисленные запросы можно использовать с помощью скрипта PHP.Сначала сценарий должен подключиться к базе данных MySQL, а затем могут отображаться записи.Вот пример кода.
Php
требуется "config.php";
$ count = "ВЫБРАТЬ * ОТ ученика ГДЕ имя LIKE '% John%'";
echo "<таблица>";
echo " id name class mark ";
foreach ($ dbo-> query ($ count) as $ row) {
echo " $ row [id] $ row [name] $ row [class] $ row [mark] < / td> ";
}
эхо "
Прочтите, как команда LIKE используется в базе данных MSSQL
Полная таблица студентов с SQL-дампом
Эта статья написана plus2net.com team.
MySQL Like Clause | Учебное пособие по MySQL от Wideskills
LIKE - очень полезный оператор в MySQL для получения данных с условиями из таблицы. Оператор LIKE часто используется с предложением WHERE в операторе select для извлечения данных из таблицы MySQL. Базовый синтаксис оператора like отображается как:
ВЫБЕРИТЕ имя, фамилию, адрес ОТ Студента ГДЕ Фамилия КАК 'ka%';
Приведенная выше команда извлекает имя, фамилию и адрес всех учащихся, чье имя начинается с буквы «ка».
MySQL предоставляет два подстановочных символа, используемых с операторами LIKE, это процент (%) и подчеркивание (_).
- Процент (%) позволяет сравнивать любую строку из нуля или более символов.
- Подчеркивание (_) позволяет сравнивать любые отдельные символы.
Мы можем использовать эти подстановочные знаки в начале, в конце или в середине значения для сравнения строки.
Использование процента в качестве подстановочного знакаПроцентное значение используется для сопоставления любого количества символов в начале или в конце данной строки.Например, у нас есть данные о названиях компаний, а также их адрес и цена какого-либо сервера.
ID | Компания | Адрес | Количество | 9327 9322 9322 | 9322 9322 | $ 1000 |
2 | Apple | Чикаго | $ 2000 | |||
$ 3000 | ||||||
4 | Asus | Сингапур | $ 15000 |
Теперь мы хотим найти компанию и адрес компании. имя начинается с буквы «А».
ВЫБЕРИТЕ ID, компанию, адрес, сумму от компании, в которой компания как «A%»;
Результат подобного запроса:
ID | Компания | Адрес | 0002 | Apple | Чикаго | $ 2000 | ||||||||||||||||||||||||||||||||||||||
4 | $ Asus | | нам нужны все строки с адресом, заканчивающимся буквой «go» SELECT ID, Company, Address, Amount from company, где компания вроде '% go'; Тогда результат:
Использование подчеркивания в качестве подстановочного знака Нижнее подчеркивание используется для соответствия указанному количеству символов в критериях соответствия.Например, у нас есть tablestudents с информацией об их имени, адресе и классе .
Теперь нам нужно найти четыре персонажа, чтобы у оператора были длинные имена. используется как: 9000 2 ВЫБЕРИТЕ ID, имя, адрес, класс из числа студентов, имя которых похоже на «____»;Здесь мы используем четыре символа подчеркивания для обозначения четырех символов в имени.Результатом указанного выше запроса выбора является:
|