sakurwars 2020-08-19 17:22 采纳率: 50%
浏览 255
已采纳

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

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

图片说明

想在结果下方加一条总计 应该怎么写?

  • 写回答

2条回答 默认 最新

  • jingluan666 2020-08-19 18:24
    关注
    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
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 安装 opencv4nodejs 报错
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!