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
    
  • 相关阅读:
    置顶功能改进
    Skin设计小组新作品发布—绿草蓝天
    代码着色功能改进
    增加了将文章收藏至网摘的功能
    [公告]C++博客开通
    [新功能]显示文章所属分类
    新Skin发布
    北京.NET俱乐部活动公告
    正式开始学习.NET 2.0
    关于共同学习.NET 2.0的想法
  • 原文地址:https://www.cnblogs.com/Mr-Cxy/p/6135701.html
Copyright © 2011-2022 走看看