SQL Query Duplicate Removal Help

后端 未结 4 513
栀梦
栀梦 2021-01-24 06:32

I need to remove semi duplicate records from the following table

ID      PID      SCORE
1       1        50
2       33       20
3       1        90
4       5             


        
相关标签:
4条回答
  • 2021-01-24 07:12
    WITH    q AS
            (
            SELECT  *, ROW_NUMBER() OVER (PARTITION BY pid ORDER BY score) AS rn
            FROM    mytable
            )
    DELETE
    FROM    q
    WHERE   rn = 1
    

    To leave the results that have no duplicates:

    WITH    q AS
            (
            SELECT  *,
                    ROW_NUMBER() OVER (PARTITION BY pid ORDER BY score) AS rn,
                    COUNT(*) OVER (PARTITION BY pid) AS cnt
            FROM    mytable
            )
    DELETE
    FROM    q
    WHERE   rn = 1
            AND cnt > 1
    
    0 讨论(0)
  • 2021-01-24 07:13

    try this..

        declare @tt table(id int, pid int,score int)
        insert into @tt
        select 1,1,50 union all
        select 2,33,50 union all
        select 8,33,80 union all
        select 3,1,90 union all
        select 4,5,50 union all
        select 5,5,10 union all
        select 6,6,10 union all
        select 7,6,50  
        ---------   
        delete from @tt where id in (
        select t1.id from @tt t1 inner join
        (
            select  MIN(score) tScore,pid tPid from @tt where pid in 
            (select  pid from @tt group by pid having count (pid) > 1) group by pid 
        ) t2 on t1.pid=t2.tPid and t1.score=t2.tScore)
    
        select * from @tt
    
    0 讨论(0)
  • 2021-01-24 07:25
        DELETE t.* 
        FROM Table1 t 
        JOIN (SELECT pid, MIN(score) minScore, MAX(id) maxId
                FROM Table1
            GROUP BY pid) t1 
        ON t.pid = t1.pid 
       AND t.score = t1.minScore 
       AND t.id < t1.maxId
    
    0 讨论(0)
  • 2021-01-24 07:30

    I can't see your query, so I've made up this example...

    SELECT
        PID,
        MAX(Score)
    FROM
        tblTable
    GROUP BY
        PID
    
    0 讨论(0)
提交回复
热议问题