查询sql,查出GROUP BY 之后的记录条数,及符合某个条件的记录条数,显示到一条记录中

SELECT CUST_NO,COUNT(*),STATUS FROM CUST_DRAFTNO WHERE DRAFT_TYPE IN ('3','4','5')AND STATUS IN ('4','5')

-- AND CUST_NO ='1234'

GROUP BY CUST_NO,STATUS

结果

CUST_NO STATUS COUNT(*)

11111 4 5

11111 5 4

11122 4 4

例如CUST_NO='11111',有4,5两个状态,我想查出CUST_NO='1111'的总条数,以及CUST_NO='1111' AND STATUS='4'的总条数,CUST_NO='1111' AND STATUS='5'的总条数。

查询结果样式为

CUST_NO COUNT1 COUNT2 COUNT3

11111 9 5 4 该如何写呢?

SELECT * FROM temp.CUST_NO ,temp.c,temp1.c1,temp2.c2
(SELECT CUST_NO,COUNT(*) c FROM CUST_DRAFTNO WHERE DRAFT_TYPE IN ('3','4','5')AND STATUS IN ('4','5') GROUP BY CUST_NO) temp 
LEFT JOIN (SELECT CUST_NO,COUNT(*)c1 FROM CUST_DRAFTNO WHERE DRAFT_TYPE IN ('3','4','5')AND STATUS IN ('4','5') AND STATUS='4'  GROUP BY CUST_NO) temp1 ON temp.CUST_NO=temp1.CUST_NO
LEFT JOIN (SELECT CUST_NO,COUNT(*) c2 FROM CUST_DRAFTNO WHERE DRAFT_TYPE IN ('3','4','5')AND STATUS IN ('4','5') AND STATUS='5'  GROUP BY CUST_NO) temp2 ON temp.CUST_NO=temp2.CUST_NO

 查出根据CUST_NO分组 的sql组成表

在使用LEFT JOIN  查出根据CUST_NO分组并且条件STATUS=4的sql组成表

继续使用LEFT JOIN  查出根据CUST_NO分组并且条件STATUS=5的sql组成表


组合查出的数据就是你要的

来自:求助得到的回答
温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2018-03-07
使用子查询,
SELECT (SELECT COUNT(*) FROM CUST_DRAFTNO CD WHERE CD.STATUS IN ('4','5') AND CD.CUST_NO=CDINFO.CUST_NO) COUNT1 FROM CUST_DRAFTNO CDINFO WHERE CDINFO.CUST_NO='11111'
OK本回答被网友采纳
第2个回答  2013-03-05
使用子查询,
SELECT(SELECT COUNT(*)FROM CUST_DRAFTNO CD,WHERE CD.STATUS('4','5')和CD.CUST_NO = CDINFO.CUST_NO的)COUNT1从CUST_DRAFTNO CDINFO,CDINFO.CUST_NO =“ 11111“
OK
相似回答