新建一张测试表:
CREATE TABLE `book` (
`id` char(32) NOT NULL DEFAULT '',
`name` varchar(100) DEFAULT NULL,
`parent_id` char(32) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
测试数据:
INSERT INTO `book` VALUES ('1', 'n1', '1');
INSERT INTO `book` VALUES ('2', 'n2', '1');
INSERT INTO `book` VALUES ('3', 'n3', '1');
INSERT INTO `book` VALUES ('4', 'n4', '3');
INSERT INTO `book` VALUES ('5', 'n5', '3');
INSERT INTO `book` VALUES ('6', 'n1', '1');
INSERT INTO `book` VALUES ('7', 'n2', '8');
INSERT INTO `book` VALUES ('8', 'n1', '5');
INSERT INTO `book` VALUES ('9', 'n4', '5');
INSERT INTO `book` VALUES ('10', 'n1', '5');
INSERT INTO `book` VALUES ('11', 'n2', '5');
查询删除重复数据前表中数据:
![mysql删除重复数据只保留一条 mysql删除重复数据只保留一条](https://image.shishitao.com:8440/aHR0cHM6Ly9iYnNtYXguaWthZmFuLmNvbS9zdGF0aWMvTDNCeWIzaDVMMmgwZEhBdlpHd3lMbWwwWlhsbExtTnZiUzkxY0d4dllXUXZZWFIwWVdOb2JXVnVkQzh3TVRFM0x6VTBNREF2TVdNNU1UWm1OVE10TkRNME9TMHpOVFZqTFdKak4yRXRPR014Tm1Sa1l6WTNNems1TG5CdVp3PT0uanBn.jpg?w=700&webp=1)
执行删除重复数据SQL:
DELETE book from book ,
(
SELECT id FROM (
SELECT id FROM book WHERE name IN(SELECT name FROM book GROUP BY name HAVING count(name) > 1)
) t
WHERE id NOT IN (SELECT id FROM book GROUP BY name HAVING count(name) > 1)
) as a
WHERE book.id = a.id;
删除重复数据后表中数据:
![mysql删除重复数据只保留一条 mysql删除重复数据只保留一条](https://image.shishitao.com:8440/aHR0cHM6Ly9iYnNtYXguaWthZmFuLmNvbS9zdGF0aWMvTDNCeWIzaDVMMmgwZEhBdlpHd3lMbWwwWlhsbExtTnZiUzkxY0d4dllXUXZZWFIwWVdOb2JXVnVkQzh3TVRFM0x6VTBNRFF2TlRsbU9Ua3dZMll0TmpneFl5MHpZbU5sTFRnNE5UTXROamc1T1RSaU1HUTFOemhtTG5CdVp3PT0uanBn.jpg?w=700&webp=1)
name列重复的数据删除了。