Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do I delete duplicate rows in SQL Server using the OVER clause?

Here are the columns in my table:

Id
EmployeeId
IncidentRecordedById
DateOfIncident
Comments
TypeId
Description
IsAttenIncident

I would like to delete duplicate rows where EmployeeId, DateOfIncident, TypeId and Description are the same - just to clarify - I do want to keep one of them. I think I should be using the OVER clause with PARTITION, but I am not sure.

Thanks

like image 731
Bill Greer Avatar asked Nov 30 '22 04:11

Bill Greer


2 Answers

If you want to keep one row of the duplicate-groups you can use ROW_NUMBER. In this example i keep the row with the lowest Id:

WITH CTE AS 
(
    SELECT rn = ROW_NUMBER() 
                OVER( 
                  PARTITION BY employeeid, dateofincident, typeid, description 
                  ORDER BY Id ASC), * 
    FROM dbo.TableName
) 
DELETE FROM cte 
WHERE  rn > 1 
like image 158
Tim Schmelter Avatar answered Dec 04 '22 09:12

Tim Schmelter


use this query without using CTE....

delete a from (select id,name,place, ROW_NUMBER() over (partition by id,name,place order by id) row_Count from dup_table) a where a.row_Count >1

like image 29
Ashok D Avatar answered Dec 04 '22 08:12

Ashok D