use Demo;with EmpCte as ( select *,ROW_NUMBER() over(partition by name order by name) as row_num from Emp ) delete from EmpCte where row_num>1Explanation : https://betechnical.blog/2018/02/18/delete-duplicate-rows-from-sql-table/
Please refer the article Remove duplicate records/data from Sql Server database table http://www.webcodeexpert.com/2013/11/how-to-remove-duplicate-recordsdata.html
CREATE TABLE dbo.duplicateTest
(
[ID] [int] ,
[FirstName] [varchar](25),
[LastName] [varchar](25)
) ON [PRIMARY]
goselect * from duplicatetestINSERT INTO dbo.duplicateTest VALUES(1, 'Bob','Smith')
INSERT INTO dbo.duplicateTest VALUES(2, 'Dave','Jones')
INSERT INTO dbo.duplicateTest VALUES(3, 'Karen','White')
INSERT INTO dbo.duplicateTest VALUES(1, 'Bob','Smith')
WITH A(rowid,ID,FirstName,LastName) AS
SELECT ROW_NUMBER() OVER (ORDER BY id ASC) AS ROWID, * FROM duplicatetest
)
Delete A from A inner join A as B ON( A.rowid <> B.rowid and A.ID=A.ID
and A.FirstName=B.FirstName
and A.LastName=B.LastName
AND A.ROWID < B.ROWID
select * from duplicatetest
SET ROWCOUNT 1
DELETE a1
FROM a1 a
WHERE (SELECT COUNT(*) FROM a1 b WHERE b.test1 = a.test1 AND b.test1 =
a.test1) > 1
WHILE @@rowcount > 0
WHERE (SELECT COUNT(*) FROM a1 b WHERE b.test1 = a.test1 AND b.test1=
SET ROWCOUNT 0