宁波网站建设咨询:宁波网站建设
13780026116 宁波网站制作
网站公告
PHP技术
技术交流
网络推广
网站建设常见问答
殷雯动态
你的位置:首页> 新闻/观点 > 网站建设常见问答>sql某一表中重复某一字段重复记录查询与处理
网站建设常见问答
sql某一表中重复某一字段重复记录查询与处理

sql某一表中重复某一字段重复记录查询与处理


1.查询出重复记录 

 select 重复记录字段 form  数据表 group by houseno having count(重复记录字段)>1


2.重复记录只显示一条ID值最小或最大的记录

 select   id,* from   数据表 where houseno (select 重复记录字段 form 数据表 group by 重复记录

字段 having count(重复记录字段)>1 )


这样把houseno重复的的ID值全部显示出,那么我们如何只显示一条id最小或最大的记录呢?

关键是在上面sql的where子句中select 重复记录字段 form 数据表 group by 重复记录字段 having count(重复记录字段)>1

修改为

select min(id) form 数据表 group by 重复记录字段 having count(重复记录字段)>1

这样就查询重复记录字段中ID最小值

那么上面的语句就是

  select   id,* from   数据表 where houseno (select min(id) form 数据表 group by 重复记录字段having count(重复记录字段)>1 )

3.至于对重复记录执行delete update 就非常简单啦

  例如只保留最小id的一条   

   delete 数据表 where id in (select max(id ) from 数据包 group by 重复记录字段 having count(重复记录字段)>1) 

  update 操作不说啦都一样。

4.group by  字段 having count与distinct的区别

distct查询显示全部字段值都是一样的唯一,一条记录

 例如

id     name   sex

43 111 1

44 111 1

45 111 2

46 222 2

47 222 2

48 333 1

49 333 1

SELECT distinct

      [name]

      ,[sex]

  FROM [database].[dbo].[a]


要想实现上面的要去掉 sex字段 改成

SELECT distinct

      [name]

     FROM [database].[dbo].[a]


但要想取得重复ID最小值不建议用distinct。

总结:


 对于重复记录关键是查出 :采用group by 字段 having count(字段)>1 

 取得最小id的一条(很关键) :采用min(id)



点击:  1027    时间: 2018-07-21
上一条: 文化局在我公司文艺演出
下一条: PHP进行批量任务处理不超时的解决方法
 
 
快速通道: 关于我们    网站建设    主机域名    付款方式    我的声明
  
联系我们
手机扫描QQ
网站建设咨询:
咨询热线:
宁波殷雯网站建设工作室
地 址: 浙江省宁波市江东区
电 话: 13780026116 
邮 箱:
waichun@qq.com
宁波网站建设
宁波网站制作
13780026116
宁波殷雯网站建设工作室 版权所有   浙ICP备16030041号-1