27,579
社区成员
发帖
与我相关
我的任务
分享
select 次数1=sum(case when n1 between 0 and 9 then 1 else 0),
次数2=sum(case when n2 between 0 and 9 then 1 else 0),
次数3=sum(case when n3 between 0 and 9 then 1 else 0)
feom tb
--生成测试数据
DECLARE @t TABLE(N1 INT,N2 INT,N3 INT);
INSERT @t
SELECT TOP(1000)
ABS(CHECKSUM(NEWID())) % 10,
ABS(CHECKSUM(NEWID())) % 10,
ABS(CHECKSUM(NEWID())) % 10
FROM sys.objects,sys.columns;
--SQL 查询如下:
SELECT
A.number,
ISNULL(B.N1_CNT,0) AS N1_CNT,
ISNULL(C.N2_CNT,0) AS N2_CNT,
ISNULL(D.N3_CNT,0) AS N3_CNT
FROM
(
SELECT number = 0 UNION ALL
SELECT number = 1 UNION ALL
SELECT number = 2 UNION ALL
SELECT number = 3 UNION ALL
SELECT number = 4 UNION ALL
SELECT number = 5 UNION ALL
SELECT number = 6 UNION ALL
SELECT number = 7 UNION ALL
SELECT number = 8 UNION ALL
SELECT number = 9
) AS A
LEFT JOIN (SELECT N1,COUNT(*) AS N1_CNT FROM @t GROUP BY N1) AS B
ON A.number = B.N1
LEFT JOIN (SELECT N2,COUNT(*) AS N2_CNT FROM @t GROUP BY N2) AS C
ON A.number = C.N2
LEFT JOIN (SELECT N3,COUNT(*) AS N3_CNT FROM @t GROUP BY N3) AS D
ON A.number = D.N3
/*
number N1_CNT N2_CNT N3_CNT
----------- ----------- ----------- -----------
0 109 107 88
1 101 109 110
2 108 109 94
3 108 100 107
4 93 95 92
5 88 95 98
6 93 78 116
7 92 114 91
8 98 107 102
9 110 86 102
(10 行受影响)
*/
SELECT
A.number,
ISNULL(B.N1_CNT,0) AS N1_CNT,
ISNULL(C.N2_CNT,0) AS N2_CNT,
ISNULL(D.N3_CNT,0) AS N3_CNT
FROM
(
SELECT number = 0 UNION ALL
SELECT number = 1 UNION ALL
SELECT number = 2 UNION ALL
SELECT number = 3 UNION ALL
SELECT number = 4 UNION ALL
SELECT number = 5 UNION ALL
SELECT number = 6 UNION ALL
SELECT number = 7 UNION ALL
SELECT number = 8 UNION ALL
SELECT number = 9
) AS A
LEFT JOIN (SELECT N1,COUNT(*) AS N1_CNT FROM tb GROUP BY N1) AS B
ON A.number = B.N1
LEFT JOIN (SELECT N2,COUNT(*) AS N2_CNT FROM tb GROUP BY N2) AS C
ON A.number = C.N2
LEFT JOIN (SELECT N3,COUNT(*) AS N3_CNT FROM tb GROUP BY N3) AS D
ON A.number = D.N3