Как сделать несколько столбцов? - PullRequest
0 голосов
/ 09 сентября 2018

Мне нужно отобразить результат в нескольких столбцах?

Пример данных

payments
user_id     amount     payment_time   sale_type
1           20          31.01.2011     card
1           10          02.01.2012     cash
3           10          03.01.2012     card
4           15          05.02.2012     bank

Мне нужен результат:

diapason     total_amount    card     cash     bank
0-10              10     
10 and more       10     

Реальный запрос

select IFnull(t.diapason,'total') as diapason, t.total_amount as 
total_amount, t.cash, t.bank 
FROM 
(SELECT CASE
when p2.amount<=10 then '0-10'
when p2.amount>10 then '10 +' END AS diapason, 
sum(p1.amount) as total_amount,
SUM(CASE WHEN p1.sale_type='cash' THEN p1.amount ELSE 0 END) as cash,
SUM(CASE WHEN p1.sale_type='bank' THEN p1.amount ELSE 0 END) as bank
FROM 
(SELECT distinct user_id, SUM(amount) AS amount, sale_type FROM payments 
where payment_time between '2018-04-12' and '2018-04-18' group by user_id) 
p1 
inner JOIN 
(SELECT DISTINCT user_id, sum(amount) AS amount FROM payments group by 
user_id) p2 
on p1.user_id = p2.user_id 
GROUP BY diapason WITH ROLLUP) t;

Это реальный запрос, но дает неправильный результат

1 Ответ

0 голосов
/ 09 сентября 2018

Вы можете попробовать это.

Я думаю, что вы ищете агрегатная функция условия

Схема (MySQL v5.7)

CREATE TABLE payments(
  user_id INT,
  amount INT,
  payment_time DATE,
  sale_type VARCHAR(50)
);

     INSERT INTO payments VALUES (1,20,'2011-01-31','card');
     INSERT INTO payments VALUES (1,10,'2012-01-02','cash');
     INSERT INTO payments VALUES (3,10,'2012-01-03','card');
     INSERT INTO payments VALUES (4,15,'2012-02-05','bank');

Запрос № 1

select (case when p2.amount <=10 then '0-10'
    else '10 and more' end) diapason,
       sum(p1.amount) total_amount,
       SUM(CASE WHEN p1.sale_type='card' THEN p1.amount ELSE 0 END) card,
       SUM(CASE WHEN p1.sale_type='cash' THEN p1.amount ELSE 0 END) cash,
       SUM(CASE WHEN p1.sale_type='bank' THEN p1.amount ELSE 0 END) bank
from 
(
  select *
  from payments
  where payment_time between '2012-01-01' and '2012-01-30' group by user_id, sale_type 
) p1
join (select user_id, sum(amount) amount
  from payments
  group by user_id) p2
on p1.user_id = p2.user_id
GROUP BY (case when p2.amount <=10 then '0-10'
    else '10 and more' end);

| diapason    | total_amount | card | cash | bank |
| ----------- | ------------ | ---- | ---- | ---- |
| 0-10        | 10           | 10   | 0    | 0    |
| 10 and more | 10           | 0    | 10   | 0    |

Просмотр на БД Fiddle

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...