![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
baryshkov |
|
|||
Новичок Профиль Группа: Участник Сообщений: 45 Регистрация: 31.10.2012 Репутация: нет Всего: нет |
Здравствуйте.
Хочу сделать фильтр но не могу построить запрос. В таблице храниться товар а во второй его харакьеристики. Делаю запрос:
И выборка не работает! Таблица j_virtuemart_products хранит инфу о продукте. j_virtuemart_product_customfields хранит инфу атрибуты продукта в формате код атрибута, значение Кажеться все дела в таблице с атрибутами...я не могу получить несколько записей с разными значениями! т.к. храняться записи код_продукта|14|4.00-8 код_продукта|13|8 Это сообщение отредактировал(а) baryshkov - 13.5.2013, 09:16 |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Это - EAV. Читайте теорию по работе с данными в этой модели. Добавлено через 3 минуты и 48 секунд Или в студию: проверенный скрипт создания таблиц, скрипт наполнения их тестовыми данными, желаемый результат на именно этих данных. И никакой кириллицы! -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Все прекрасно работает, просто из исходного набора данных просто физически не возможно выбрать такие строки, где значение virtuemart_custom_id было бы одновременно равно и 14 и 13, потому пустой результат - совершенно правильный результат для этого запроса.
-------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
baryshkov |
|
||||
Новичок Профиль Группа: Участник Сообщений: 45 Регистрация: 31.10.2012 Репутация: нет Всего: нет |
Спасибо автору, сделал как тут http://otvety.google.ru/otvety/thread?tid=2bf0cad3f737aead
Добавлено @ 10:25
Спасибо, ваш способ тоже работает Это сообщение отредактировал(а) baryshkov - 13.5.2013, 10:28 |
||||
|
|||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
-------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Vas |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 830 Регистрация: 29.6.2005 Где: Stavropol region Репутация: нет Всего: 28 |
А почему нельзя было использовать OR?
Этот ответ добавлен с нового Винграда - http://vingrad.com |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Потому что условие OR вернет запись для которой атрибут 14 равен '4.00-8', а атрибут 13 не равен '8' -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Vas |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 830 Регистрация: 29.6.2005 Где: Stavropol region Репутация: нет Всего: 28 |
И все таки наверно вернет записи с id 14 равным '4.00-8' ИЛИ id 13 равным '8'
Этот ответ добавлен с нового Винграда - http://vingrad.com |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Наверно вернет. Но наверно ТС нужны записи, для которых именно оба атрибута установлены в определенные значения, а не только один из них. Если следовать предложенной вами логике, можно вобще убрать фильтрацию в where, потому как среди того, что вернется без фильтрации, таки действительно все равно будет то, что нам действительно нужно. -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Vas |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 830 Регистрация: 29.6.2005 Где: Stavropol region Репутация: нет Всего: 28 |
Разница только в том, что с использованием OR вернется не одна запись, а две, что конечно не есть гуд.
[offtop] Подскажите как цитировать? [/offtop] Этот ответ добавлен с нового Винграда - http://vingrad.com |
|||
|
||||
Wowa |
|
|||
Эксперт ![]() Профиль Группа: Админ Сообщений: 15017 Регистрация: 14.9.2000 Где: Винград Репутация: нет Всего: 290 |
[ quote ] [/ quote ] только без пробелов )
Этот ответ добавлен с нового Винграда - http://vingrad.com |
|||
|
||||
Vas |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 830 Регистрация: 29.6.2005 Где: Stavropol region Репутация: нет Всего: 28 |
Да, согласен, OR в таком случае не подойдет этот момент слегка упустил.
Этот ответ добавлен с нового Винграда - http://vingrad.com |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Подойдет, но только в купе с group by product_id и having count(*) = 2(или 3,4,5 в зависимости от количества атрибутов по которым мы отбираемся). В ряде случаев такое решение может оказаться более эффективем нежели мульти джойн. -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
![]() ![]() ![]() |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |