sql server:计数记录

时间:2011-09-28 20:49:28

标签: sql sql-server

我有一个tableA(ID int,Match varchar,tot int)

ID Match Tot
1  123
2  123
3  12
4  12
5  4
6  12
7  8

现在,我想计算Tot,这是表中存在的匹配总数。例如123发生两次,12发生三次,依此类推。另请注意,我只想在第一场比赛时计算。这是预期的结果。:

ID Match Tot
1  123    2
2  123
3  12     3
4  12
5  4      1
6  12
7  8      1

另一个案例:

    ID Match Count Tot
    1  123   2
    2  123   1
    3  12    10
    4  12    10
    5  4     3
    6  12    5
    7  8     7

现在我想为同一场比赛添加点数。预期结果:

    ID Match Count Tot
    1  123   2      3
    2  123   1
    3  12    10     25
    4  12    10
    5  4     3       3
    6  12    5  
    7  8     7       7

由于

3 个答案:

答案 0 :(得分:2)

WITH tableA(ID, Match) AS
(
SELECT 1,123 UNION ALL
SELECT 2,123 UNION ALL
SELECT 3,12 UNION ALL
SELECT 4,12 UNION ALL
SELECT 5,4 UNION ALL
SELECT 6,12 UNION ALL
SELECT 7,8
)
SELECT *,
       CASE
         WHEN ROW_NUMBER() OVER (PARTITION BY Match ORDER BY ID) = 1 
         THEN COUNT(*) OVER (PARTITION BY Match)
       END AS Tot
FROM   tableA
ORDER  BY ID  

答案 1 :(得分:1)

SELECT match, COUNT(match ) as Tot
FROM tableA
GROUP BY match

答案 2 :(得分:0)

解决方案1:

DECLARE @MyTable TABLE
(
    ID INT PRIMARY KEY
    ,Match VARCHAR(10) NOT NULL
    ,Tot INT NULL
);
INSERT  @MyTable(ID, Match)
SELECT 1,  123
UNION ALL
SELECT 2,  123
UNION ALL
SELECT 3,  12
UNION ALL
SELECT 4,  12
UNION ALL
SELECT 5,  4
UNION ALL
SELECT 6,  12
UNION ALL
SELECT 7,  8;

--SELECT
SELECT  *
        ,CASE 
            WHEN ROW_NUMBER()OVER(PARTITION BY a.Match ORDER BY a.ID ASC)=1
            THEN COUNT(*)OVER(PARTITION BY a.Match)
        END TotCalculated
FROM    @MyTable a;

--UPDATE
WITH MyCTE
AS
(
    SELECT  a.Tot
            ,CASE 
                WHEN ROW_NUMBER()OVER(PARTITION BY a.Match ORDER BY a.ID ASC)=1
                THEN COUNT(*)OVER(PARTITION BY a.Match)
            END TotCalculated
    FROM    @MyTable a
)
UPDATE  MyCTE 
SET     Tot = TotCalculated;

SELECT  *
FROM    @MyTable;

解决方案2:

UPDATE  @MyTable
SET     Tot = NULL;

SELECT  x.ID, y.Num
FROM
(
    SELECT  b.Match, MIN(b.ID) ID
    FROM    @MyTable b
    GROUP BY b.Match
) x INNER JOIN
(
    SELECT  a.Match, COUNT(*) AS Num
    FROM    @MyTable a
    GROUP BY a.Match
) y ON x.Match = y.Match
ORDER BY x.ID

UPDATE  @MyTable
SET     Tot = t.Num
FROM    @MyTable z 
INNER JOIN
(
        SELECT  x.ID, y.Num
        FROM
        (
            SELECT  b.Match, MIN(b.ID) ID
            FROM    @MyTable b
            GROUP BY b.Match
        ) x INNER JOIN
        (
            SELECT  a.Match, COUNT(*) AS Num
            FROM    @MyTable a
            GROUP BY a.Match
        ) y ON x.Match = y.Match
) t     ON z.ID = t.ID;

SELECT  *
FROM    @MyTable;