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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Ошибка запроса. 
:(
    Опции темы
baryshkov
Дата 13.5.2013, 09:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Здравствуйте.
Хочу сделать фильтр но не могу построить запрос.
В таблице храниться товар а во второй его харакьеристики.
Делаю запрос:
Код

SELECT * FROM j_virtuemart_products, j_virtuemart_product_customfields
WHERE j_virtuemart_products.virtuemart_product_id = j_virtuemart_product_customfields.virtuemart_product_id 
AND virtuemart_custom_id=14 AND custom_value='4.00-8' 
AND virtuemart_custom_id=13 AND custom_value='8' 
ORDER BY j_virtuemart_products.virtuemart_product_id 

И выборка не работает!

Таблица  j_virtuemart_products хранит инфу о продукте.
j_virtuemart_product_customfields хранит инфу атрибуты продукта в формате код атрибута, значение

Кажеться все дела в таблице с атрибутами...я не могу получить несколько записей с разными значениями!
т.к. храняться записи
код_продукта|14|4.00-8
код_продукта|13|8

Это сообщение отредактировал(а) baryshkov - 13.5.2013, 09:16
PM MAIL   Вверх
Akina
Дата 13.5.2013, 09:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Цитата(baryshkov @  13.5.2013,  10:03 Найти цитируемый пост)
атрибуты продукта в формате код атрибута, значение

Это - EAV. Читайте теорию по работе с данными в этой модели.

Добавлено через 3 минуты и 48 секунд
Или в студию: проверенный скрипт создания таблиц, скрипт наполнения их тестовыми данными, желаемый результат на именно этих данных. И никакой кириллицы!


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

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


Чо?
****


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

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



Цитата(baryshkov @  13.5.2013,  10:03 Найти цитируемый пост)
И выборка не работает!

Все прекрасно работает, просто из исходного набора данных просто физически не возможно выбрать такие строки, где значение virtuemart_custom_id было бы одновременно равно и 14 и 13, потому пустой результат - совершенно правильный результат для этого запроса.

Код

SELECT * FROM j_virtuemart_products, j_virtuemart_product_customfields as vpc1, j_virtuemart_product_customfields as vpc2
WHERE j_virtuemart_products.virtuemart_product_id = vpc1.virtuemart_product_id 
and j_virtuemart_products.virtuemart_product_id = vpc2.virtuemart_product_id 
AND vpc1.virtuemart_custom_id=14 AND vpc1.custom_value='4.00-8' 
AND vpc2.virtuemart_custom_id=13 AND vpc2.custom_value='8' 
ORDER BY j_virtuemart_products.virtuemart_product_id 



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
baryshkov
Дата 13.5.2013, 10:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Спасибо автору, сделал как тут http://otvety.google.ru/otvety/thread?tid=2bf0cad3f737aead

Добавлено @ 10:25
Цитата(Zloxa @ 13.5.2013,  09:56)
Цитата(baryshkov @  13.5.2013,  10:03 Найти цитируемый пост)
И выборка не работает!

Все прекрасно работает, просто из исходного набора данных просто физически не возможно выбрать такие строки, где значение virtuemart_custom_id было бы одновременно равно и 14 и 13, потому пустой результат - совершенно правильный результат для этого запроса.

Код

SELECT * FROM j_virtuemart_products, j_virtuemart_product_customfields as vpc1, j_virtuemart_product_customfields as vpc2
WHERE j_virtuemart_products.virtuemart_product_id = vpc1.virtuemart_product_id 
and j_virtuemart_products.virtuemart_product_id = vpc2.virtuemart_product_id 
AND vpc1.virtuemart_custom_id=14 AND vpc1.custom_value='4.00-8' 
AND vpc2.virtuemart_custom_id=13 AND vpc2.custom_value='8' 
ORDER BY j_virtuemart_products.virtuemart_product_id 

Спасибо, ваш способ тоже работает

Это сообщение отредактировал(а) baryshkov - 13.5.2013, 10:28
PM MAIL   Вверх
Zloxa
Дата 13.5.2013, 11:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(baryshkov @  13.5.2013,  11:24 Найти цитируемый пост)
ваш способ тоже

Это один и тот же способ


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Vas
Дата 13.5.2013, 14:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

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



А почему нельзя было использовать OR?
Код

SELECT * FROM j_virtuemart_products, j_virtuemart_product_customfields
WHERE j_virtuemart_products.virtuemart_product_id = j_virtuemart_product_customfields.virtuemart_product_id
AND ((virtuemart_custom_id=14 AND custom_value='4.00-8') OR (virtuemart_custom_id=13 AND custom_value='8')) 
ORDER BY j_virtuemart_products.virtuemart_product_id


Этот ответ добавлен с нового Винграда - http://vingrad.com
PM MAIL   Вверх
Zloxa
Дата 13.5.2013, 14:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(Vas @  13.5.2013,  15:19 Найти цитируемый пост)
А почему нельзя было использовать OR?

Потому что условие OR вернет запись для которой атрибут 14 равен '4.00-8', а атрибут 13 не равен '8'


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Vas
Дата 13.5.2013, 14:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

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



И все таки наверно вернет записи с id 14 равным '4.00-8' ИЛИ id 13 равным '8'
Код

((virtuemart_custom_id=14 AND custom_value='4.00-8') OR (virtuemart_custom_id=13 AND custom_value='8'))


Этот ответ добавлен с нового Винграда - http://vingrad.com
PM MAIL   Вверх
Zloxa
Дата 13.5.2013, 14:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(Vas @  13.5.2013,  15:41 Найти цитируемый пост)
И все таки наверно вернет записи с id 14 равным '4.00-8' ИЛИ id 13 равным '8'

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

Если следовать предложенной вами логике, можно вобще убрать фильтрацию в where, потому как среди того, что вернется без фильтрации, таки действительно все равно будет то, что нам действительно нужно.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Vas
Дата 13.5.2013, 14:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

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



Разница только в том, что с использованием OR вернется не одна запись, а две, что конечно не есть гуд.
[offtop]
Подскажите как цитировать?
[/offtop]

Этот ответ добавлен с нового Винграда - http://vingrad.com
PM MAIL   Вверх
Wowa
Дата 13.5.2013, 15:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
Group Icon


Профиль
Группа: Админ
Сообщений: 15017
Регистрация: 14.9.2000
Где: Винград

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



[ quote ]    [/ quote ]   только без пробелов )

Этот ответ добавлен с нового Винграда - http://vingrad.com
PM WWW   Вверх
Vas
Дата 13.5.2013, 15:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

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



Да, согласен, OR в таком случае не подойдет этот момент слегка упустил.

Этот ответ добавлен с нового Винграда - http://vingrad.com
PM MAIL   Вверх
Zloxa
Дата 13.5.2013, 15:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(Vas @  13.5.2013,  16:12 Найти цитируемый пост)
Да, согласен, OR в таком случае не подойдет этот момент слегка упустил.

Подойдет, но только в купе с group by product_id и having count(*) = 2(или 3,4,5 в зависимости от количества атрибутов по которым мы отбираемся). В ряде случаев такое решение может оказаться более эффективем нежели мульти джойн.


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


 




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


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

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