Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Выобрка

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
jonston
Отправлено: 26 Июля, 2013 - 01:55:34
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Есть 3 таблицы (приложены файлом).Как мне выбрать товар у которого в таблице product_attribute есть и запись со значением поля attribute_id = 1 и запись со значением поля attribute_id = 5.OR не подходит так как если отсутствует запись с каким либо атрибутом, то запись не нужно выбирать.Как это делается?Я знаю что это элементарно.Но как?
Прикреплено изображение (Нажмите для увеличения)
table2.jpg

(Отредактировано автором: 26 Июля, 2013 - 01:56:23)



-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
DeepVarvar Супермодератор
Отправлено: 26 Июля, 2013 - 02:01:05
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




А если атрибута три а не два?
 
 Top
jonston
Отправлено: 26 Июля, 2013 - 02:02:15
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




DeepVarvar пишет:
А если атрибута три а не два?

Как вариант тоже может быть


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
DeepVarvar Супермодератор
Отправлено: 26 Июля, 2013 - 02:07:36
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Так что? Выбрать все продукты у которых максимум атрибутов?
Например у продукта 1 три атрибута, а пр 2 тоже три, а пр 3 только один.
Выбрать первый и второй продукты?
 
 Top
jonston
Отправлено: 26 Июля, 2013 - 02:11:28
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




DeepVarvar пишет:
Так что? Выбрать все продукты у которых максимум атрибутов?
Например у продукта 1 три атрибута, а пр 2 тоже три, а пр 3 только один.
Выбрать первый и второй продукты?


выбери продукт у которого присутствует и атрибут 1 и атрибут 5.Хотя бы так Дальше я пойму сам.Но если в таблице product_attribute нет хотя бы одного из них то не нужно выбирать.Можно так же добавить атрибут 6.По идее должен выбрать продукт с id 10


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
DeepVarvar Супермодератор
Отправлено: 26 Июля, 2013 - 02:32:02
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Короче http://www.askdev.ru/question/18936/%D0%92%D1%8B%D0%B1%D0%BE%D1%80%D0%BA%D0%B0-%D1%82%D0%BE%D0%B2%D0%B0%D1%80%D0%BE%D0%B2-%D0%B8%D0%B7-%D0%B1%D0%B0%D0%B7%D1%8B-%D0%BF%D0%BE-%D1%84%D0%B8%D0%BB%D1%8C%D1%82%D1%80%D0%B0%D0%BC/

Но пока искал это, нашел афигенную штуку: http://habrahabr[dot]ru/qa/4983/#answer_21464
Камент стоит прочитать, класс! Вот у себя именно так и сделаю!
 
 Top
jonston
Отправлено: 26 Июля, 2013 - 02:42:22
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Благодарю!То есть мне нужно одну и ту же таблицу объединить join и уже ставить дополнительный AND?

Насчет второй статьи я еще слабоват понимать выражение загнать в 128 битное число.Примерно понял что там идет сильная оптимизация запроса с кэшем.Так?
(Добавление)
DeepVarvar пишет:
Короче http://www.askdev.ru/question/18936/%D0%92%D1%8B%D0%B1%D0%BE%D1%80%D0%BA%D0%B0-%D1%82%D0%BE%D0%B2%D0%B0%D1%80%D0%BE%D0%B2-%D0%B8%D0%B7-%D0%B1%D0%B0%D0%B7%D1%8B-%D0%BF%D0%BE-%D1%84%D0%B8%D0%BB%D1%8C%D1%82%D1%80%D0%B0%D0%BC/


Отлично!!!Спасибо получилось!Я догадывался что нужно join делать, но думал будет висеть запрос конкретно.Оказалось нет!

(Отредактировано автором: 26 Июля, 2013 - 02:42:37)



-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
esterio
Отправлено: 26 Июля, 2013 - 10:11:01
Post Id



Активный участник


Покинул форум
Сообщений всего: 5025
Дата рег-ции: Нояб. 2012  
Откуда: Украина, Львов


Помог: 127 раз(а)




А вот и статья из коментария
http://habrahabr[dot]ru/post/114113/
Тлько я все равно мало догнал суть
 
 Top
EuGen Администратор
Отправлено: 26 Июля, 2013 - 10:26:20
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




DeepVarvar, esterio, старая как мир хеш-карта. Суть как раз в том, что задача сводится к первичной фильтрации - то есть путём построения карты удаётся выбрать первичное множество строк, гораздо меньшее, чем вся исходная таблица - и уже потом из этого множества делается полноценный (соответствующий всем критериям) выбор. Не сработает при низкой релевантности запроса. Иными словами, если есть дипапзон [a..b] и в таблице значение поля изменяется в диапазоне [A..B], то эффективность построения карты стремится к нулю при a->A, b->B. Для битового ключа - эффективность стремится к нулю при стремлении выборки чекбоксов к (bin)md5(1{128}). Впрочем, любой другой индекс в этом случае тоже покажет плохой результат (FULL SCAN), но удивляться и не приходится - такова суть низкой релевантности.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB