求助!各路大神 在查询结果中加一行“总计”

有两个表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

以上是 求助!各路大神 在查询结果中加一行“总计” 的全部内容, 来源链接: utcz.com/a/39861.html

回到顶部