我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么在mysql数据库中删除重复的数据

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么在mysql数据库中删除重复的数据

本篇文章为大家展示了怎么在mysql数据库中删除重复的数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1.问题引入

假设一个场景,一张用户表,包含3个字段。id,identity_id,name。现在身份证号identity_id和姓名name有很多重复的数据,需要删除只保留一条有效数据。

2.模拟环境

登入mysql数据库,创建一个单独的测试数据库mysql_exercise

create database mysql_exercise charset utf8;

创建用户表users

create table users(id int auto_increment primary key,identity_id varchar(20),name varchar(20) not null     );

怎么在mysql数据库中删除重复的数据

插入测试数据

insert into users values(0,'620616199409206512','张三'),(0,'620616199409206512','张三'),(0,'62062619930920651X','李四'),(0,'62062619930920651X','李四'),(0,'620622199101206211','王五'),(0,'620622199101206211','王五'),(0,'322235199909116233','赵六');

可以多执行几次,生成较多重复数据。

怎么在mysql数据库中删除重复的数据

4.解决思路

(1)根据身份证号和name进行分组;

(2)取出分组后的最大id(或最小id);

(3)删除除最大(或最小)id以外的其他字段;

第一次尝试(失败!!!)

delete from users where id not in (select max(id) from users group by identity_id,name);

报错:

1093 (HY000): You can't specify target table 'users' for update in FROM clause

怎么在mysql数据库中删除重复的数据

因为在MYSQL里,不能先select一个表的记录,再按此条件进行更新和删除同一个表的记录。

解决办法是,将select得到的结果,再通过中间表select一遍,这样就规避了错误,

这个问题只出现于mysql,mssql和oracle不会出现此问题。

所以我们可以先将括号里面的sql语句先拿出来,先查到最大(或最小)id。

select max_id from (select max(id) as max_id from users group by identity_id,name);

接着,又报错了!!!

ERROR 1248 (42000): Every derived table must have its own alias

意思是说:提示说每一个衍生出来的表,必须要有自己的别名!

执行子查询的时候,外层查询会将内层的查询当做一张表来处理,所以我们需要给内层的查询加上别名

怎么在mysql数据库中删除重复的数据

继续更正:

给查询到的最大(或最小id)结果当做一张新的表,起别名t,并查询t.mix_id。

select t.max_id from (select max(id) as max_id from users group by identity_id,name) as t;

可以成功查到最大(或最小)id了,如下图:

怎么在mysql数据库中删除重复的数据

6.第二次尝试(成功!!!)

delete from users where id not in (select t.max_id from (select max(id) as max_id from users group by identity_id,name) as t);

执行结果:

怎么在mysql数据库中删除重复的数据

成功将重复的数据删除,只保留了最后一次增加的记录。同理也可以保留第一次添加的记录(即删除每个分组里面除最小id以外的其他条记录)

3.知识拓展一:更新数据

其他场景应用:要将用户表user_info里名字(name)为空字符串("")的用户的状态(status)改成"0"

update user_info set status='0' where user_id in (select user_id from user_info where name='')

同样报了如下错误:

You can't specify target table ‘user_info' for update in FROM clause

因为在MYSQL里,不能先select一个表的记录,再按此条件进行更新和删除同一个表的记录,解决办法是,将select得到的结果,再通过中间表select一遍,这样就规避了错误。
以下两种均可!!!

update user_info set status='0' where user_id in  (select user_id from (select user_id from user_info where name = '') t1);

下面这种也可,细微差别,别名可带as可不带,t1.user_id 直接和内层的user_id对应也可以。

update user_info set status='0' where user_id in (select t1.user_id from (select user_id from user_info where name='') as t1);

3.1 分步骤解析

(1)将以下查询结果作为中间表:

select user_id from user_info where name='';

(2)再查询一遍中间表作为结果集:

select user_id from (select user_id from user_info where name='') as t;

(3)更新数据

update user_info set status='0' where user_id in (select user_id from (select user_id from user_info where name='') as t1);

4.拓展练习:删除重复数据

编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。

+----+------------------+| Id | Email      |+----+------------------+| 1 | john@example.com || 2 | bob@example.com || 3 | john@example.com |+----+------------------+

Id 是这个表的主键。

例如,在运行你的查询语句之后,上面的 Person 表应返回以下几行:

+----+------------------+| Id | Email      |+----+------------------+| 1 | john@example.com || 2 | bob@example.com |+----+------------------+

解答一:

delete from Person where Id not in (select t.min_id from (select min(Id) as min_id from Person group by Email) as t);

解答二:

delete p1 from Person as p1,Person as p2 where p1.Email=p2.Email and p1.Id > p2.Id;

上述内容就是怎么在mysql数据库中删除重复的数据,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么在mysql数据库中删除重复的数据

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么在mysql数据库中删除重复的数据

本篇文章为大家展示了怎么在mysql数据库中删除重复的数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.问题引入假设一个场景,一张用户表,包含3个字段。id,identity_id,name。现
2023-06-07

mysql数据库怎么删除重复数据库

mysql 中删除重复数据库的过程如下:使用查询识别重复数据库。使用 drop database 语句删除重复数据库。使用 show databases 验证重复数据库是否已删除。如何删除 MySQL 中的重复数据库MySQL 中删除重复
mysql数据库怎么删除重复数据库
2024-08-05

怎么删除mysql重复数据库

如何删除 mysql 重复数据库查找重复数据库(使用 show databases 命令)。连接到要删除的数据库(使用 use database 命令)。删除数据库中所有表(使用 drop table 命令)。删除重复数据库(使用 drop
怎么删除mysql重复数据库
2024-08-05

mysql数据库怎么删除重复

在 MySQL 数据库中删除重复项的方法有:SELECT DISTINCT column1, column2, ...FROM table_name;SELECT column1, column2, ...FROM table_nameGR
mysql数据库怎么删除重复
2024-08-05

数据库mysql怎么删除重复项

要从 mysql 数据库中删除重复项,可以采取以下步骤:确定要删除重复项的列或组合列。使用 distinct 或 group by 语句删除重复行。使用 delete with 关键字永久删除重复行,确保按主键排序。如何从 MySQL 数据
数据库mysql怎么删除重复项
2024-08-05

mysql中怎么删除重复数据

在MySQL中,可以使用以下两种方法来删除重复数据:方法1:使用DISTINCT关键字和INSERT INTO SELECT语句CREATE TABLE new_table ASSELECT DISTINCT * FROM old_t
mysql中怎么删除重复数据
2024-04-09

怎么恢复mysql数据库中删除的数据库

要恢复已删除的 mysql 数据库,首先确认其已删除。然后,有两种恢复方法:使用备份文件或从二进制日志文件恢复。从备份文件恢复需要先停止服务器、复制文件并运行查询。从二进制日志文件恢复则需要确保日志记录已启用,提取操作并运行查询创建并恢复数
怎么恢复mysql数据库中删除的数据库
2024-04-14

mysql中怎么删除数据库数据

mysql中删除数据的方法包括:删除整个数据库(drop database database_name;)、删除表中所有数据(truncate table table_name;)、删除表中特定行(delete from table_nam
mysql中怎么删除数据库数据
2024-08-05

mysql数据库表数据删除怎么恢复

mysql 数据删除恢复方法:从备份中恢复:还原已创建的数据库备份。恢复日志恢复:使用启用的恢复日志记录来解析并恢复数据。undo 日志恢复:回滚 undo 日志以恢复已删除的数据。第三方工具恢复:利用第三方工具恢复已删除的数据。注意:恢复
mysql数据库表数据删除怎么恢复
2024-08-05

mysql数据库删除怎么恢复

mysql 数据库中删除的数据恢复方法:检查回收站(mysql 8.0 及以上版本)使用备份恢复使用二进制日志恢复(需启用 binlog)MySQL 数据库删除恢复问题:MySQL 数据库中删除的数据如何恢复?回答:数据恢复是 MyS
mysql数据库删除怎么恢复
2024-08-05

mysql删除数据库怎么恢复

已删除的 mysql 数据库的恢复方法有两种:从备份恢复(停止服务、复制备份文件、恢复数据库),或从二进制日志恢复(找到关联的 binlog 文件、提取事件、重建数据库、应用事件)。恢复前务必备份现有数据,关闭使用数据库的应用程序。请尝试使
mysql删除数据库怎么恢复
2024-05-21

编程热搜

目录