MySQL_关于用嵌套表计算的可以不用 20161205

Posted Mr_Cxy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL_关于用嵌套表计算的可以不用 20161205相关的知识,希望对你有一定的参考价值。

计算求和类的指标,其实用不到嵌套表,比如计算各城市产品分类的订单额。

如果要计算不重复的指标 比如一个用户一天下了多个订单 用这样的表计算一天有多少用户下单 这个用户肯定是去重的 下多个订单也应该视为一个用户

这个用嵌套表主要是为了逻辑理解清楚 一步步来,如果对数据库表很熟悉的话可以省去嵌套表的步骤

1、嵌套表

##C024_02 上周品类销售收入
SELECT  CONCAT(b.分类ID,‘-‘,a.产品分类) AS 商品分类
,SUM(IF(城市="城市A",销售确认额,NULL)) AS 城市A,SUM(IF(城市="城市B",销售确认额,NULL)) AS 城市B,SUM(IF(城市="城市C",销售确认额,NULL)) AS 城市C
,SUM(IF(城市="城市D",销售确认额,NULL)) AS 城市D,SUM(IF(城市="城市E",销售确认额,NULL)) AS 城市E
FROM (#上周一到本周一
    SELECT 城市,a2.产品分类,SUM(销售额) AS 销售确认额
    FROM `a005_account` AS a1
    LEFT JOIN `a002_产品` AS a2 ON a1.产品ID=a2.产品ID
    WHERE 应收日>=DATE_ADD(DATE(DATE_ADD(CURRENT_DATE,INTERVAL -WEEKDAY(CURRENT_DATE) DAY)),INTERVAL -1 WEEK) AND 应收日<DATE(DATE_ADD(CURRENT_DATE,INTERVAL -WEEKDAY(CURRENT_DATE) DAY))
    GROUP BY 城市,a2.产品分类
) AS a
LEFT JOIN `a000_cate` AS b ON a.产品分类=b.产品分类
GROUP BY a.产品分类
ORDER BY b.分类ID

 2、不用嵌套

##C024_02 上周品类销售收入
SELECT  CONCAT(a3.分类ID,‘-‘,a2.产品分类) AS 商品分类
,SUM(IF(城市="城市A",销售额,NULL)) AS 城市A,SUM(IF(城市="城市B",销售额,NULL)) AS 城市B,SUM(IF(城市="城市C",销售额,NULL)) AS 城市C
,SUM(IF(城市="城市D",销售额,NULL)) AS 城市D,SUM(IF(城市="城市E",销售额,NULL)) AS 城市E
FROM `a005_account` AS a1
LEFT JOIN `a002_产品` AS a2 ON a1.产品ID=a2.产品ID
LEFT JOIN `a000_cate` AS a3 ON a2.产品分类=a3.产品分类
WHERE 应收日>=DATE_ADD(DATE(DATE_ADD(CURRENT_DATE,INTERVAL -WEEKDAY(CURRENT_DATE) DAY)),INTERVAL -1 WEEK) AND 应收日<DATE(DATE_ADD(CURRENT_DATE,INTERVAL -WEEKDAY(CURRENT_DATE) DAY))
GROUP BY a2.产品分类
ORDER BY a3.分类ID

 

以上是关于MySQL_关于用嵌套表计算的可以不用 20161205的主要内容,如果未能解决你的问题,请参考以下文章

关于mysql的优化

使用算术运算优化 MySQL 嵌套选择

mysql怎么在查询中嵌套子查询

如何使用 Python 将嵌套字典/json 插入 MySQL 表

mysql中insert与select的嵌套使用解决组合字段插入问题

SQL多表模糊查询