Поиск MySQL FULLTEXT возвращает только точное совпадение

Я добавил индекс FULLTEXT в таблицу следующим образом:

ALTER TABLE TEST ADD FULLTEXT(name, descrip, notes);

Таблица TEST состоит из 100 строк. Я обновил столбец descrip, указав «ветвь» в одной строке и «ветки» в другой строке.

Тогда я бегу

SELECT * FROM TEST WHERE MATCH(name, descrip, notes) AGAINST ('branch' IN BOOLEAN MODE);

Результат вернул только строки, содержащие слово «ветвь». «Ветви» не включаются в результат, даже если они состоят из искомого слова. Как включить «Филиалы»? Я хочу избежать использования LIKE.

Я не уверен, что полнотекстовый поиск работает с подстроками.

Tim Biegeleisen 15.06.2018 06:07
Освоение архитектуры микросервисов с 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
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
2
1
304
2

Ответы 2

В логическом режиме вы можете использовать подстановочный знак:

AGAINST ('branch*' IN BOOLEAN MODE);

Вот ваш вопрос. Вам нужно использовать подстановочный знак.

SELECT * FROM TEST WHERE MATCH(name, descrip, notes) AGAINST ('branch*' IN BOOLEAN MODE);

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