查询sql,查出GROUP BY 之后的记录条数,及符合某个条件的记录条数,显示到一条记录中
SELECTCUST_NO,COUNT(*),STATUSFROMCUST_DRAFTNOWHEREDRAFT_TYPEIN('3','4','5')ANDSTATUSI...
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 该如何写呢? 展开
-- 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 该如何写呢? 展开
3个回答
展开全部
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组成表
组合查出的数据就是你要的
来自:求助得到的回答
展开全部
使用子查询,
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
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
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
使用子查询,
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
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
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询