Последние новости:

Поиск по сайту:

Лисп-программисту известна ценность всего, но неизвестна цена чего бы то ни было. (Алан.Дж.Перлис)

SQL — Операторы Wildcards (Подстановочные операторы)

1 мин для чтения
1 Звезда2 Звезды3 Звезды4 Звезды5 Звезд (2 оценок, среднее: 5,00 из 5)
Загрузка...
23.04.2017
SQL - Операторы Wildcards (Подстановочные операторы)

Мы уже говорили об операторе SQL LIKE, который используется для сравнения значения для аналогичных значений с использованием операторов подстановки.

SQL поддерживает два подстановочных оператора в сочетании с оператором LIKE, которые подробно описаны в следующей таблице.

 

Подстановочные операторы & Описание
1Знак процента (%)

Соответствует одному или более символов.

Примечание — MS Access использует символ звездочки (*) символ подстановки вместо знака процента (%) подстановочный знак.

2Подчеркивание (_)

Соответствует одному символу.

Примечание — MS Access использует знак вопроса вместо подчеркивания (_) , чтобы соответствовать любому символу (?).

 

Знак процента представляет ноль, один или несколько символов. Подчеркивание представляет собой одно целое число или символ. Эти символы могут быть использованы в комбинации.

 

Синтаксис

Основной синтаксис «%» и «_» оператора заключается в следующем.

SELECT FROM table_name
WHERE column LIKE 'XXXX%'

or 

SELECT FROM table_name
WHERE column LIKE '%XXXX%'

or

SELECT FROM table_name
WHERE column LIKE 'XXXX_'

or

SELECT FROM table_name
WHERE column LIKE '_XXXX'

or

SELECT FROM table_name
WHERE column LIKE '_XXXX_'

 

Вы можете объединить N число условий с помощью операторов AND или OR. Здесь XXXX может быть любым числовым или строковым значением.

 

Примеры

В следующей таблице имеется ряд примеров, показывающих, где часть, имеющую различные положения с операторами «_» и «%».

Заявление и описание
1WHERE SALARY LIKE ‘200%’

Находит все значения, которые начинаются с 200.

2WHERE SALARY LIKE ‘%200%’

Находит все значения, которые имеют 200 в любом положении.

3WHERE SALARY LIKE ‘_00%’

Находит все значения, которые имеют 00 во второй и третьей позиции.

4WHERE SALARY LIKE ‘_00%’

Находит все значения, которые начинаются с 2, и по меньшей мере, 3-х символов в длину.

5WHERE SALARY LIKE ‘2_%_%’

Находит любые значения, которые заканчиваются 2.

6WHERE SALARY LIKE ‘%2’

Находит любые значения, которые имеют 2 во втором положении и в конце с 3.

7WHERE SALARY LIKE ‘_2%3’

Находит любые значения в пять-значного числа, которые начинаются с 2 и заканчивается 3.

 

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

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Maxim    |  35 | Moscow    | 21000.00 |
|  2 | AndreyEx |  38 | Krasnodar | 55500.00 |
|  3 | Oleg     |  33 | Rostov    | 34000.00 |
|  4 | Masha    |  35 | Moscow    | 31500.00 |
|  5 | Ruslan   |  34 | Omsk      | 43000.00 |
|  6 | Dima     |  32 | SP        | 45000.00 |
|  7 | Roma     |  34 | SP        | 10000.00 |
+----+----------+-----+-----------+----------+

 

Следующий блок кода является примером, который отобразит все записи из таблицы CUSTOMERS, где SALARY начинается с 55.

SQL> SELECT * FROM CUSTOMERS
WHERE SALARY LIKE '55%';

 

Это даст следующий результат:

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  2 | AndreyEx |  38 | Krasnodar | 55500.00 |
+----+----------+-----+-----------+----------+

 

Если вы нашли ошибку, пожалуйста, выделите фрагмент текста и нажмите Ctrl+Enter.

Если статья понравилась, то поделитесь ей в социальных сетях:

Читайте также

0 0 голоса
Рейтинг статьи
Подписаться
Уведомить о
guest

**ссылки nofollow

1 Комментарий
Старые
Новые Популярные
Межтекстовые Отзывы
Посмотреть все комментарии
Сергей

Мне кажется, что человек, который понимает язык этой статьи, уже знает ответ на вопрос, в чём разница между статическим и динамическим SQL. А я не понял. Я хотел понять, в чём разница между статическим и динамическим запросом. Яндекс даёт эту статью на первой странице в ответ на запрос «Что такое динамический запрос». Вроде статья должна ответить на этот вопрос, но уровень явно для академиков.

Статьи партнеров:

1
0
Оставьте комментарий! Напишите, что думаете по поводу статьи.x

Сообщить об опечатке

Текст, который будет отправлен нашим редакторам:

Заполните форму и наш менеджер перезвонит Вам в самое ближайшее время!

badge
Обратный звонок 1
Отправить

Спасибо! Ваша заявка принята

close

Спасибо! Ваша заявка принята

close