zoukankan      html  css  js  c++  java
  • SQL交叉表

    之前做货品横向展示时,有看到评论说用到交叉表。

    公司最近需要给订单表做一个数据汇总的功能,同事给到一个参考SQL

    select * from (select COUNT(1) as 已锁定 from tbl_order where orderLock = 1) as A,
    (select COUNT(1) as 未锁定 from tbl_order where orderLock = 0) as B,
    (select COUNT(1) as 未发货 from tbl_order where PushStatus=1 and statusid=14) as C,
    (select COUNT(1) as 待发货 from tbl_order where PushStatus=1 and statusid=14 and isshipments=1) as D,
    (select COUNT(1) as 已发货 from tbl_order where statusid=4) as E,
    (select COUNT(1) as 未分配 from tbl_order where statusid = 14 and PushStatus<>3 and pushstatus=0) as F,
    (select COUNT(1) as 已分配 from tbl_order where PushStatus=1) as G,
    (select COUNT(1) as 已推送 from tbl_order where PushStatus=2) as H

    看完改为下面SQL

    SELECT
    COUNT(CASE WHEN orderLock=1 THEN 1 ELSE NULL END) AS '已锁定',
    COUNT(CASE WHEN orderLock=0 THEN 1 ELSE NULL END) AS '未锁定',
    COUNT(CASE WHEN PushStatus=1 and statusid=14 THEN 1 ELSE NULL END) AS '未发货',
    COUNT(CASE WHEN PushStatus=1 and statusid=14 and isshipments=1 THEN 1 ELSE NULL END) AS '待发货',
    COUNT(CASE WHEN statusid=4 THEN 1 ELSE NULL END) AS '已发货',
    COUNT(CASE WHEN statusid = 14 and PushStatus<>3 and pushstatus=0 THEN 1 ELSE NULL END) AS '未分配',
    COUNT(CASE WHEN PushStatus=1 THEN 1 ELSE NULL END) AS '已分配',
    COUNT(CASE WHEN PushStatus=2 THEN 1 ELSE NULL END) AS '已推送'
    FROM tbl_order

    与上面参考SQL相比只用到了一次查询表,并且如果有where条件更利于扩展。

    直接上图 SQL执行计划参考:

     

     这个差距显而易见,欢迎大家提出更加优化的SQL。 

  • 相关阅读:
    MySQL-事务相关知识
    Linux脚本-自动ping网址列表
    洛谷 P2453 [SDOI2006]最短距离
    洛谷 P2915 [USACO08NOV]Mixed Up Cows G
    洛谷 P2473 [SCOI2008] 奖励关
    洛谷 P3391 【模板】文艺平衡树
    洛谷 P4146 序列终结者
    洛谷 P1486 [NOI2004] 郁闷的出纳员
    洛谷 P2596 [ZJOI2006]书架
    性能测试工具Jmeter02-安装配置
  • 原文地址:https://www.cnblogs.com/Tangcy/p/5610069.html
Copyright © 2011-2022 走看看