powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Объединение полей и поиск по ним CONCAT_WS + LIKE
9 сообщений из 9, страница 1 из 1
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962685
xew
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
xew
Гость
Имеется таблица users с полями lastname, firstname, middlename
Нужно объединить поля и найти нужного пользователя

Объединение делаю так:
авторSELECT CONCAT_WS(' ', lastname, firstname, middlename) search FROM users

Вопрос: Как реализовать LIKE с этим запросом и возможно ли ?

Пробовал так:
авторSELECT CONCAT_WS(' ', lastname, firstname, middlename) search FROM users WHERE search LIKE '%Попова%'
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962689
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
В WHERE нельзя ссылаться на алиасы из секции SELECT.
Код: sql
1.
2.
3.
SELECT CONCAT_WS(' ', lastname, firstname, middlename) search
FROM users
WHERE CONCAT_WS(' ', lastname, firstname, middlename) LIKE '%Попова%'


Правда, непонятно, зачем тут конкатенация, когда можно три лайка сделать.
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962704
xew
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
xew
Гость
miksoft,

Спасибо, уже зам допер:
авторselect search from (SELECT CONCAT_WS(' ', lastname, firstname, middlename) AS search FROM users) result WHERE search LIKE '%Попова%'


Кому надо :)
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962708
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
xewmiksoft,

Спасибо, уже зам допер:
авторselect search from (SELECT CONCAT_WS(' ', lastname, firstname, middlename) AS search FROM users) result WHERE search LIKE '%Попова%'


Кому надо :)Не, так точно не надо.
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962710
xew
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
xew
Гость
miksoft, пчму ?
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962716
miksoft
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
xewmiksoft, пчму ?Потому что не надо тащить подзапросы там, где они не нужны. А то они ненароком и материализоваться могут.
Да и сложность чтения/поддержки возрастает.

Если уже настолько не хочется повторять выражение (хотя тут оно и вовсе не нужно), то используйте HAVING.
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962724
xew
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
xew
Гость
miksoft, спасибо)
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962786
вадя
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ну лучше так
Код: sql
1.
2.
3.
SELECT  lastname, firstname, middlename
FROM users
WHERE CONCAT_WS(' ', lastname, firstname, middlename) LIKE '%Попова%'
...
Рейтинг: 0 / 0
Объединение полей и поиск по ним CONCAT_WS + LIKE
    #38962819
Фотография Akina
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
вадя , ну ничем не лучше, да к тому же не соответствует задаче. Единственное вменяемое улучшение уже указано - использовать поиск по отдельным полям, без конкатенации, чтобы индексы работали.
...
Рейтинг: 0 / 0
9 сообщений из 9, страница 1 из 1
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Объединение полей и поиск по ним CONCAT_WS + LIKE
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]