zoukankan      html  css  js  c++  java
  • 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
    
  • 相关阅读:
    二分查找法
    Three-way Partition
    百面机器学习读书笔记
    天才在左,疯子在右
    Coach Shane's Daily English Dictaion 6-10
    Coach Shane's Daily English Dictation 1-5
    国外有意思的网站
    docker操作指南
    创建docker本地仓库的步骤
    tensorflow去掉warning的方法
  • 原文地址:https://www.cnblogs.com/Mr-Cxy/p/6135701.html
Copyright © 2011-2022 走看看