Получить наибольшее количество товаров / пользователей

id | user_id | prd_id | amnt | dis
1  |   1     |  10    |  200 | 23
2  |   2     |  10    |  300 | 11
3  |   3     |  20    |  100 | 26
4  |   2     |  20    |  50  | 12
5  |   4     |  30    |  100 | 22
6  |   2     |  40    |  600 | 18
7  |   2     |  30    |  100 | 16

Я хочу 2 результата из таблицы выше:

Первый by prod_id как показано ниже

prd_id |  user_id  | cont |   highestamt | disc
10     |   2       |  2   |   300        | 11
20     |   3       |  2   |   100        | 26
30     |   4       |  2   |   100        | 22
40     |   2       |  1   |   600        | 18

второй by user_id как показано ниже:

user_id | cont |  bid on prd_id    | winner on bid prod_id |
1       |  1   |   10              |  -                    |   -
2       |  4   |   10,20,30,40     |  10,40                |
3       |  1   |   20              |  20                   |
4       |  1   |   30              |  30                   |

ОБНОВЛЕНИЕ: например: выше: user_id = 2 имеет ставку на продукт 10,20,30,40 (ставка на prd_id), следовательно, его ставка остается равной 4 … и из которой он выигрывает в 10,40 (победитель на ставке prod_id) .. ПОЧЕМУ ТОЛЬКО 10 , 40, а не 30 … bcz user_id = 4 сделал ставку на prd = 30 с amt = 100 и user_id = 2 с amt = 100 .. но первая ставка была сделана пользователем = 4 на prd = 30, следовательно, он выиграл prd = 30 (для того же времени)

Попробовал ниже запрос для by prd_id но это дает мне какой-то неправильный результат.

SELECT `prd_id`, `user_id` , count('prd_id') as cont , max(`amnt`) as highestamt,disc
FROM `proddtails`
group by `prd_id` order by `prd_id`

выше результат запроса, как показано ниже: ( user_id,disc не подходит)

prd_id |  user_id  | cont |   highestamt | disc
10     |   2       |  2   |   300        | 11
20     |   2       |  2   |   100        | 11
30     |   2       |  1   |   100        | 11
40     |   2       |  1   |   600        | 11

Для второго by user_id Я не понимаю, что будет запрос.

Спасибо

ОБНОВИТЬ :

СПАСИБО ДЛЯ HARSHIL: http://www.sqlfiddle.com/#!9/5325a6/5/1

но после еще одной записи я нашел эту ошибку: http://www.sqlfiddle.com/#!9/e04063/1 для второго: для user_id но хорошо работает для prd_id (первый запрос)

user_id  cont   bid_on_prd_id   winner_on_bid_prod_id
1         1         10                  (null)
2         4     10,20,40,30            10,40,30
3         1        20                     20
4         1        30                     30

но я хочу как ниже:

без нулевого user_id

user_id  cont   bid_on_prd_id   winner_on_bid_prod_id
2         4     10,20,30,40             10,40
3         1        20                     20
4         1        30                     30

с нулевым user_id (но на моем wamp-сервере я не вижу null в winner_on_bid_prd_id для user_id = 1, я получаю значение 10 вместо нуля)

user_id  cont   bid_on_prd_id   winner_on_bid_prod_id
1         1         10                  (null)
2         4     10,20,30,40             10,40
3         1        20                     20
4         1        30                     30

3

Решение

Для prd_id:

select t1.prd_id,t1.user_id,
(select count(*) from tablename where prd_id = t1.prd_id)as cont,
t1.amnt as highststatment,
t1.dis as disc
from tablename t1
where (t1.prd_id,t1.amnt) in
(select prd_id, max(amnt) from tablename group by prd_id)
group by t1.prd_id;

Для usr_id:

    select t1.user_id,
count(*) as cont,
Group_concat(t1.prd_id separator ',') as bid_on_prd_id,
(select Group_concat(distinct t2.prd_id separator ',')
from tablename t2
where t2.user_id = t1.user_id
and (t2.id) in
(select min(id) from tablename
where (prd_id,amnt) in
(select prd_id,max(amnt) from tablename group by prd_id)
group by prd_id
)
) as winner_on_bid_prod_id
from tablename t1
group by t1.user_id
having winner_on_bid_prod_id IS NOT NULL;

Нажмите здесь для ОБНОВЛЕНО ДЕМО

4

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]