有两个表a表
b表
按照下面语句得出结果
select
a.mode,
sum(case when b.mytime = '2020-08-01' then ifnull(b.total_price,0) else 0 end) 2020年8月1日,
sum(case when b.mytime = '2020-08-02' then ifnull(b.total_price,0) else 0 end) 2020年8月2日,
sum(case when b.mytime = '2020-08-03' then ifnull(b.total_price,0) else 0 end) 2020年8月3日,
sum(case when b.mytime = '2020-08-04' then ifnull(b.total_price,0) else 0 end) 2020年8月4日,
sum(case when b.mytime LIKE '2020-08%' then ifnull(b.total_price,0) else 0 end) 8月金额总计
from
a a
left join
b b
on a.id = b.pid
group by a.mode
order by a.mode asc;
想在结果下方加一条总计 应该怎么写?
SELECT IFNULL(MODE,'总计') AS '销售模式',2020年8月1日,2020年8月2日,2020年8月2日,2020年8月3日,2020年8月4日,8月金额总计
FROM
(
SELECT
a.mode,
SUM(CASE WHEN b.mytime = '2020-08-01' THEN IFNULL(b.total_price,0) ELSE 0 END) 2020年8月1日,
SUM(CASE WHEN b.mytime = '2020-08-02' THEN IFNULL(b.total_price,0) ELSE 0 END) 2020年8月2日,
SUM(CASE WHEN b.mytime = '2020-08-03' THEN IFNULL(b.total_price,0) ELSE 0 END) 2020年8月3日,
SUM(CASE WHEN b.mytime = '2020-08-04' THEN IFNULL(b.total_price,0) ELSE 0 END) 2020年8月4日,
SUM(CASE WHEN b.mytime LIKE '2020-08%' THEN IFNULL(b.total_price,0) ELSE 0 END) 8月金额总计
FROM
(SELECT * FROM a ORDER BY MODE) AS a
LEFT JOIN
b b
ON a.id = b.pid
GROUP BY a.mode
WITH ROLLUP
) AS TEMP
可以在你的查询后面用union()一个相同列的行,内容是你的统计。
不过一般来说,这个都是放在应用程序里做的。