Регулярное выражение MySQL как "если"

Мне нужно пропустить слова DORM, Dorm и dorm с помощью регулярного выражения, но оставить их, если после этого есть слово PREMIUM, Premium или premium. Как я могу это сделать? Как я понял, я могу пропустить "DORM, Dorm and dorm" с этим регулярным выражением (^DORM|Dorm|dorm), но как мне сделать это "если" после этого?

Что вы имеете в виду, "пропустить использование регулярного выражения"? выбрать все записи, в которых в определенном поле нет «общежития»? Кроме того, (^DORM|Dorm|dorm) - это странное регулярное выражение, которое соответствует DORM в начале строки, но Dorm или dorm в любом месте строки ...?

Amadan 31.10.2018 11:00

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

Caius Jard 31.10.2018 11:00

Должен ли «DORM» быть в начале строки, или он может быть где угодно в строке?

Rick James 01.11.2018 06:51
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
3
3
56
1

Ответы 1

Было бы более эффективно, если бы сортировка (сортировка, заканчивающаяся на ci) выполняла свертывание регистра за вас. Если вас это устраивает, то это может быть самый простой вариант:

WHERE str LIKE '%dorm%premium%'

Эквивалентное регулярное выражение медленнее:

WHERE str REGEXP 'dorm.*premium'

Но, если вам нужны границы слов, это работает в regexp, но не в like:

WHERE str REGEXP '[[:<:]]dorm[[:>:]].*[[:<:]]premium[[:>:]]'

Есть много проблем с Вопросом (и, следовательно, с моим Ответом):

  • Почему у вас был "якорь" (^) перед DORM, а перед остальными нет?
  • Что делать, если в строке есть слово dormitory?
  • Как следует лечить doRM?
  • Есть ли причина настаивать на регулярном выражении?
  • Что вы имели в виду под словом «пропускать слова»? REGEXP (или LIKE) при использовании в предложении WHERE «пропускает строки».

Другие вопросы по теме