SQL重复记录查询

时间:2021-07-23 01:52:49

查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
SQL重复记录查询select from people
SQL重复记录查询where peopleId in (select  peopleId  from  people  group  by  peopleId  having  count(peopleId) 1)

 例如: select * from testtable where numeber in (select number from people group by number having count(number) > 1 ) 可以查出testtable表中number相同的记录 

例如:

产品参数表rule_product_info 同一个申请单是否有多条记录

用select app_no,count(1) from rule_product_info group by app_no having count(1)>1

 

2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
SQL重复记录查询delete from people 
SQL重复记录查询where peopleId  in (select  peopleId  from people  group  by  peopleId   having  count(peopleId) > 1)
SQL重复记录查询and rowid not in (select min(rowid) from  people  group by peopleId  having count(peopleId )>1)
SQL重复记录查询
SQL重复记录查询3、查找表中多余的重复记录(多个字段) 
SQL重复记录查询select * from vitae a
SQL重复记录查询where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq  having count(*> 1)
SQL重复记录查询
SQL重复记录查询4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
SQL重复记录查询delete from vitae a
SQL重复记录查询where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq having count(*> 1)
SQL重复记录查询and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
SQL重复记录查询
SQL重复记录查询
SQL重复记录查询5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
SQL重复记录查询select * from vitae a
SQL重复记录查询where (a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq having count(*> 1)
SQL重复记录查询and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)

 

(二)
SQL重复记录查询比方说
SQL重复记录查询在A表中存在一个字段“name”,
SQL重复记录查询而且不同记录之间的“name”值有可能会相同,
SQL重复记录查询现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;
SQL重复记录查询Select Name,Count(*From A Group By Name Having Count(*1
SQL重复记录查询
SQL重复记录查询如果还查性别也相同大则如下:
SQL重复记录查询Select Name,sex,Count(*From A Group By Name,sex Having Count(*1