首页 >

mysql 按组查询,MySQL数据库如何删除重复数据 – 数据库 – 前端,mysql 奇数偶数

mysql数据库基础与实例教程,mysql workbench数据导出,grafana图形展示mysql,厦门mysql培训哪家好,mysql join表,mysql 奇数偶数mysql 按组查询,MySQL数据库如何删除重复数据 - 数据库 - 前端,mysql 奇数偶数数据准备

示例表 Student_Information 如下 :

大家插入一部分数据到该表,其中存在多条姓名为 Anaa 的手机号码重复数据,如下:

入库后数据如下:

设计删除SQL

大家通过Group by对手机号进行分组,然后计算每组最大ID作为保留数据,然后删除其他数据。SQL设计如下:

执行该SQL,结果如下:

大家可以看到,该SQL删除了重复的数据时,并且保留了id最大的数据(最新数据)。

设计该SQL时需要注意什么?

大家需要注意,使用 MySQL 进行 Delete From 操作时,若子查询的 FROM 字句和更新、删除对象使用同一张表时,会出现”You can’t specify target table for update in FROM clause”。错误。

比如,大家设计如下SQL,该SQL从语法来看也是实现删除 Student_Information 表重复数据,大家执行一下看下结果。

执行结果如下,大家可以看到抛出了”You can’t specify target table for update in FROM clause”错误,那么该如何解决呢?

解决这个问题的方法也很简单,就是将 select 出的结果通过中间表再 select 一遍即可,如下:

mysql数据库基础与实例教程,mysql workbench数据导出,grafana图形展示mysql,厦门mysql培训哪家好,mysql join表,mysql 奇数偶数mysql 按组查询,MySQL数据库如何删除重复数据 - 数据库 - 前端,mysql 奇数偶数


mysql 按组查询,MySQL数据库如何删除重复数据 - 数据库 - 前端,mysql 奇数偶数
  • mysql数据库中文,mysql中注释显示中文乱码怎么解决 - 数据库 - 前端,mysql 一行数据大小排序
  • mysql数据库中文,mysql中注释显示中文乱码怎么解决 - 数据库 - 前端,mysql 一行数据大小排序 | mysql数据库中文,mysql中注释显示中文乱码怎么解决 - 数据库 - 前端,mysql 一行数据大小排序 ...

    mysql 按组查询,MySQL数据库如何删除重复数据 - 数据库 - 前端,mysql 奇数偶数
  • mysql or查询优化,如何进行SQL性能优化 - 数据库 - 前端,mysql 获取异常信息
  • mysql or查询优化,如何进行SQL性能优化 - 数据库 - 前端,mysql 获取异常信息 | mysql or查询优化,如何进行SQL性能优化 - 数据库 - 前端,mysql 获取异常信息 ...

    mysql 按组查询,MySQL数据库如何删除重复数据 - 数据库 - 前端,mysql 奇数偶数
  • plsql调试器怎么用 - 数据库 - 前端|
  • plsql调试器怎么用 - 数据库 - 前端| | plsql调试器怎么用 - 数据库 - 前端| ...