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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> MsSQL: Все комбинации связ. product_id=>product_id, В пределах order_id 
V
    Опции темы
enoff
Дата 24.9.2013, 17:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Всем привет!  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 
PM MAIL ICQ Skype GTalk   Вверх
Zloxa
Дата 24.9.2013, 22:48 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Код

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

?

Это сообщение отредактировал(а) Zloxa - 24.9.2013, 22:50


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


Опытный
**


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

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



Спасибо огромное за помощь
Как все просто  smile 
PM MAIL ICQ Skype GTalk   Вверх
Akina
Дата 26.9.2013, 12:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


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


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

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



Цитата(Zloxa @  24.9.2013,  23:48 Найти цитируемый пост)
Код

and b1.product_id != b2.product_id 

А не задвоится? АБ - БА ?


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

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




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


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

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