数据库删除重复记录示例
来源:互联网 发布:股票主力成本软件 编辑:程序博客网 时间:2024/05/21 00:20
在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢?谢谢!
1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
select * from people
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
delete from people
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
and rowid not in (select min(rowid) from people group by peopleId having count(peopleId )>1)
3、查找表中多余的重复记录(多个字段)
select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
delete from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
比方说在A表中存在一个字段“name”,而且不同记录之间的“name”值有可能会相同,
现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;
Select Name,Count(*) From A Group By Name Having Count(*) > 1
- 数据库删除重复记录示例
- 数据库删除重复记录
- 删除数据库重复记录
- 删除数据库重复记录
- 删除数据库重复记录
- 删除数据库重复记录
- 数据库重复记录删除
- 删除数据库中重复记录
- 删除数据库中重复记录
- 数据库中删除重复记录
- oracle数据库删除重复记录
- 删除数据库中的重复记录(仅删除重复的)
- 删除数据库中重复的记录
- 如何删除数据库中重复的记录
- 删除SQL Server数据库中重复记录
- Oracle数据库删除重复记录的方法
- 关于如何删除数据库中重复记录
- 常用删除数据库重复记录方法
- 二级取模分配方案中的陷阱与最优化
- Linux的核心版本
- 【小阅读^大脑袋】0809 NO.398
- JSP应用中JDK和TOMCAT环境的问题
- ASM API
- 数据库删除重复记录示例
- C/C++——深入理解sizeof
- Linux的優缺點
- Ubuntu上NFS的安装配置
- POJ 1163 The Triangle (DP)
- vbs脚本:CreateTextFile
- mysql 驱动名称不正确导致的错误
- C++ TCHAR数组转换为C#的System::String类型
- Linux下的Samba学习(一)------linux和windows互访!