MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据)

作者:追逐时光 时间:2024-01-14 14:15:33 

开发背景:

最近在做一个批量数据导入到MySQL数据库的功能,从批量导入就可以知道,这样的数据在插入数据库之前是不会进行重复判断的,因此只有在全部数据导入进去以后在执行一条语句进行删除,保证数据唯一性。

下面话不多说了,来一起看看详细的介绍吧

实战:

表结构如下图所示:

表明:brand

MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据) 

操作:

使用SQL语句查询重复的数据有哪些:


SELECT * from brand WHERE brandName IN(
select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1 #条件是数量大于1的重复数据
)

使用SQL删除多余的重复数据,并保留Id最小的一条唯一数据:

注意点:

错误SQL:DELETE FROM brand WHERE brandName IN (select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1)
AND Id NOT IN (select MIN(Id) from brand GROUP BY brandName HAVING COUNT(brandName)>1) 

提示: You can't specify target table 'brand' for update in FROM clause   不能为FROM子句中的更新指定目标表“brand”

原因是:不能将直接查处来的数据当做删除数据的条件,我们应该先把查出来的数据新建一个临时表,然后再把临时表作为条件进行删除功能


正确SQL写法:
DELETE FROM brand WHERE brandName IN (SELECT brandName FROM (SELECT brandName FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) e)
AND Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) t)

#查询显示重复的数据都是显示最前面的几条,因此不需要查询是否最小值

结果如下图:

MySQL查询重复数据(删除重复数据保留id最小的一条为唯一数据)

总结:

很多东西都是需要自己一步一步的去探究的,当然网上的建议也是非常宝贵的借鉴和资源,无论做什么开发我们都需要理解它的工作原理才能够更好的掌握它。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

来源:https://www.cnblogs.com/Can-daydayup/p/10454336.html

标签:mysql,重复,去重
0
投稿

猜你喜欢

  • 通过PYTHON来实现图像分割详解

    2023-12-08 16:02:46
  • python求最大值最小值方法总结

    2023-06-24 08:03:26
  • git_stats web代码图形统计工具详解

    2023-10-29 23:16:03
  • Python实现解析命令行参数的常见方法总结

    2023-10-15 12:31:49
  • vue+elementUI实现动态面包屑

    2024-05-02 17:11:02
  • python dataframe astype 字段类型转换方法

    2022-02-19 07:58:50
  • Python中用sleep()方法操作时间的教程

    2023-11-27 10:45:28
  • Python select及selectors模块概念用法详解

    2022-11-30 20:06:24
  • php获取给定日期相差天数的方法分析

    2024-05-02 17:34:20
  • IE7的web标准之道 Ⅱ

    2008-08-13 12:50:00
  • 解决VIM显示utf-8文件乱码问题

    2023-04-30 07:02:14
  • Django ForeignKey与数据库的FOREIGN KEY约束详解

    2024-01-18 15:17:40
  • 详解Python的条件语句

    2021-03-04 08:27:56
  • Python3+OpenCV实现简单交通标志识别流程分析

    2021-03-12 06:37:41
  • opera img onload重复执行

    2008-01-17 12:01:00
  • 关于pycharm找不到MySQLdb模块的解决方法

    2024-01-13 01:51:20
  • 用Python实现爬取百度热搜信息

    2023-12-28 22:22:20
  • Python开发微信公众平台的方法详解【基于weixin-knife】

    2023-03-09 12:05:43
  • Python3数据库操作包pymysql的操作方法

    2024-01-28 20:01:34
  • DWCS3-CSS布局之一CSS规则大纲

    2008-06-11 18:48:00
  • asp之家 网络编程 m.aspxhome.com