MsSQL: Все комбинации связ. product_id=>product_id

 
0
 
SQL
ava
enoff | 24.09.2013, 18:59
Всем привет!  smile 

Задача: Получить список связанных товаров. Два товара являются связанными, если находятся в одном заказе (order_id).
Так же необходимо вычислить релевантность (сколько раз товар продавался с другим).
Выборка должна быть вида:
product_id | related_id | relevance

Таблица basket:
id | product_id (varchar) | order_id (varchar)

1 | 1 | 1
2 | 2 | 1
3 | 3 | 1

4 | 1 | 2
5 | 2 | 2
6 | 4 | 2

7 | 1 | 3
8 | 1 | 3
9 | 5 | 3

Т.е. результат:
product_id | related_id | relevance
1 | 2 | 2
1 | 3 | 1
1 | 4 | 1
1 | 5 | 1
2 | 1 | 2
2 | 3 | 1
2 | 4 | 1
...

В таблице ~2 млн. записей. Идеально - получить все на чистом SQL (если что, то еще php участвует). Скорость выполнения - не критично, служебный скрипт.

Сервер - Microsoft SQL Server 2008 R2.

Сам не осилил  smile 
Comments (3)
ava
Zloxa | 24.09.2013, 22:48 #

select b1.product_id,b2.product_id,count(*/*либо distinct b1.order_id*/)
from basket b1
inner join basket b2 on b1.order_id =b2.order_id  and b1.product_id != b2.product_id
group by b1.product_id,b2.product_id

?
ava
enoff | 26.09.2013, 12:36 #
Спасибо огромное за помощь
Как все просто  smile 
ava
Akina | 26.09.2013, 12:39 #
Цитата (Zloxa @  24.9.2013,  23:48 findReferencedText)


and b1.product_id != b2.product_id 


А не задвоится? АБ - БА ?
Please register or login to write.
Firm of day
Вы также можете добавить свою фирму в каталог IT-фирм, и публиковать статьи, новости, вакансии и другую информацию от имени фирмы.
Подробнее
Contributors
  Akina ava  Zloxa   enoff
advanced
Submit