Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Помогите правильно построить запрос 
:(
    Опции темы
Poveritov
Дата 24.3.2017, 12:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 34
Регистрация: 25.2.2015

Репутация: нет
Всего: нет



есть запрос типа

select * from userget

WHERE   
 
     ( 
     MATCH(SUBSTRING_INDEX(userget.uname, " ", -1)) AGAINST ('...текст...' IN BOOLEAN MODE)  
     )
         AND  
             
         ( 
         MATCH(SUBSTRING_INDEX(userget.uname, " ", -1)) AGAINST ('...текст...' IN BOOLEAN MODE)  
         )


userget.uname = 'Имя Фамилия', нужно сначала проверить есть такое имя в тексте, а потом фамилия.
Ругается на использование SUBSTRING_INDEX в Match

пробовал задать параметры в 
select 

@name1 := SUBSTRING_INDEX(userget.uname, " ", -1),
@name2 := SUBSTRING_INDEX(userget.uname, " ", 1)

from 

и подставить в match(@name1) но не помогло.


Подскажите как решить данную проблему?
PM MAIL   Вверх
Akina
Дата 24.3.2017, 15:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20570
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 453



У тебя всё наоборот - ты ищешь текст в фамилии...

Добавлено через 2 минуты и 45 секунд
И потом - MATCH .. AGAINST - это поиск по полнотекстовому индексу. То есть поиск нужного фрагмента в заранее проиндексированных полях. А не в текстовых литералах или выражениях.

Для поиска литерала в поле или значения поля в литерале используй LOCATE (или INSTR). При необходимости указывай требуемый COLLATION.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Poveritov
Дата 24.3.2017, 15:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 34
Регистрация: 25.2.2015

Репутация: нет
Всего: нет



Цитата(Akina @  24.3.2017,  15:05 Найти цитируемый пост)
У тебя всё наоборот - ты ищешь текст в фамилии...



так мне и нужно искать текст в фамилии, только сначала в Имени, а потом в Фамилии.


LOCATE (или INSTR) увеличивает время ответа на 80%.
Match позволил с оптимизировать с 30 секунд на 5
PM MAIL   Вверх
tzirechnoy
Дата 24.3.2017, 16:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1173
Регистрация: 30.1.2009

Репутация: 3
Всего: 16



Так выбери всех подозрительных через быстрый MATCH, а заодно отфильтруй их правильным INSTR.

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

Собственно, дажэ безо всяких не -- именно это будет единственно правильным.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.1061 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.