文章详情页
SQL Server删除表中的重复数据
浏览:21日期:2023-03-06 14:25:22
添加示例数据
create table Student(ID varchar(10) not null,Name varchar(10) not null,);insert into Student values("1", "zhangs");insert into Student values("2", "zhangs");insert into Student values("3", "lisi");insert into Student values("4", "lisi");insert into Student values("5", "wangwu");
删除Name重复多余的行,每个Name仅保留1行数据
1、查询表中Name 重复的数据
select Name from Student group by Name having count(Name) > 1
2、有唯一列,通过唯一列最大或最小方式删除重复记录
检查表中是否有主键或者唯一值的列,当前可以数据看到ID是唯一的,可以通过Name分组排除掉ID最大或最小的行
delete from Student where Name in( select Name from Student group by Name having count(Name) > 1) and ID not in(select max(ID) from Student group by Name having count(Name) > 1 )
执行删除脚本后查询
3、无唯一列使用ROW_NUMBER()函数删除重复记录
如果表中没有唯一值的列,可以通过row_number 来删除重复数据
重复执行插入脚本,查看表数据,表中没有唯一列值
Delete T From (Select Row_Number() Over(Partition By [Name] order By [ID]) As RowNumber,* From Student)T Where T.RowNumber > 1
小知识点
语法:ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN)
表示根据COLUMN分组,在分组内部根据 COLUMN排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的)
函数“Row_Number”必须有 OVER 子句。OVER 子句必须有包含 ORDER BY
Row_Number() Over(Partition By [Name] order By [ID]) 表示已name列分组,在每组内以ID列进行升序排序,每组内返回一个唯一的序号
执行删除脚本后查询表数据
到此这篇关于SQL Server删除表中重复数据的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持。
标签:
MsSQL
相关文章:
1. 如何在SQL Server 2005中为安装程序增加计数器注册表项值2. SQL Server 数据库的更改默认备份目录的详细步骤3. Sql server 2005带来的分页便利4. SQL Script tips for MS SQL Server5. MyEclipse添加SQL Server 2008数据库的方法6. SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询7. SQL Server一个字符串拆分多行显示或者多行数据合并成一个字符串8. sql server的几个函数要记录9. Sql server优化50法10. SQL Server的死锁说明
排行榜
