![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
yukodev |
|
||||||||
Новичок Профиль Группа: Участник Сообщений: 24 Регистрация: 29.6.2012 Репутация: нет Всего: нет |
Здравствуйте.
На сайте есть система фильтров. Нужно чтоб выборка товаров работала одним запросом. Основная таблица 'products' - поля id,name,watch,img Таблица параметров: 'products_parameters' - поля: product_id,parameter_id,parameters_value_id Если параметры не выбраны то идет обычная выборка
Если же параметры выбраны то как сделал я: 1.выбираем все товары
и берем с них массив id(он нам нужен для следующих запросов с параметрами) 2.Цикл по полученным параметрам
в цикле у нас запрос(на орм):
В каждой итерации цикла мы ищем товары, выбираем их id в масив, и эти id используем в следующей итерации. Таким образом фильтрация работает правильно но такой подход очень нагружает систему. Можно ли как то это делать одним запросом с зависимыми подзапросами? |
||||||||
|
|||||||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Не можно, а нужно. Будет что-то вроде
-------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
yukodev |
|
|||
Новичок Профиль Группа: Участник Сообщений: 24 Регистрация: 29.6.2012 Репутация: нет Всего: нет |
А разве используя OR мы не нарушим логику фильтров, ведь должны выбраться товары которые будут иметь все выбранные фильтра, а тут если я не ошибаюсь будут выбраны товары в которых найден хотя бы один из фильтров, замена OR на AND даст нужный результат или появятся дополнительные нюансы?
|
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Ошибаетесь. Разберитесь в логике работы запроса, что ли... -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
yukodev |
|
|||
Новичок Профиль Группа: Участник Сообщений: 24 Регистрация: 29.6.2012 Репутация: нет Всего: нет |
Akina, Ясно спасибо
|
|||
|
||||
![]() ![]() ![]() |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |