利用主键删除重复数据

CREATE TABLE `user1_test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `user_name` varchar(20) DEFAULT NULL,
  `over` varchar(20) DEFAULT NULL,
  `mobile` varchar(200) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `user1_test` VALUES (‘1‘, ‘唐僧‘, ‘qujing‘, ‘12345678901,12345678902,12345678903‘);
INSERT INTO `user1_test` VALUES (‘2‘, ‘猪八戒‘, ‘qujing‘, ‘22345678901,22345678902,22345678903‘);
INSERT INTO `user1_test` VALUES (‘3‘, ‘孙悟空‘, ‘qujing‘, ‘32345678901,32345678902‘);
INSERT INTO `user1_test` VALUES (‘4‘, ‘沙僧‘, ‘qujing‘, ‘42345678901‘);
INSERT INTO `user1_test` VALUES (‘8‘, ‘唐僧‘, ‘qujing‘, ‘12345678901,12345678902,12345678903‘);
INSERT INTO `user1_test` VALUES (‘9‘, ‘猪八戒‘, ‘qujing‘, ‘22345678901,22345678902,22345678903‘);

MySQL-利用主键删除重复数据

1.查询数据是否重复

SELECT user_name,COUNT(*)
FROM user1_test
GROUP BY user_name
HAVING COUNT(*)>1;

2.删除重复数据,对于相同数据保留ID最大的

SELECT a.*,b.* FROM user1_test a JOIN(
 SELECT user_name,COUNT(*),MAX(id) AS id
 FROM user1_test
 GROUP BY user_name HAVING COUNT(*)>1) b
ON a.user_name=b.user_name
WHERE a.id<b.id;

DELETE a FROM user1_test a JOIN(
 SELECT user_name,COUNT(*),MAX(id) AS id
 FROM user1_test
 GROUP BY user_name HAVING COUNT(*)>1) b
ON a.user_name=b.user_name
WHERE a.id<b.id;

原文地址:https://www.cnblogs.com/ooo0/p/12252739.html

时间: 2024-11-06 14:03:08

利用主键删除重复数据的相关文章

MSSQL如何在没有主键的表中删除重复数据

为了对重复数据进行实验,下面建一个设计不太好(没有主键)表并插入了一些重复数据: create database testdb use testdb ; go create table DupsNoPK (Col1 int Null, Col2 char(5) Null ); go insert DupsNoPK(Col1,Col2) Values(1,'abc'), (2,'abc'), (2,'abc'), (2,'abc'), (7,'xyz'), (7,'xyz'); 为了验证表确实有重

SQL语句删除重复数据

1.如表中没有主键,先添加自动增长主键 alter table 表名 add 列名 int identity (1,1) primary key 2.删除重复数据 delete from 表名 where id not in (select min(id) from 表名 group by id)

mysql 删除重复数据

如题:mysql 数据库删除重复数据 因为是mysql 所以其他数据哭的命令在mysql 中是不能使用的.不要想当然的使用sql 脚本 delete from table1 where field1 in (select field1 from table1 group by field1 having count(field1) > 1) and rowid not in (select min(rowid) from table1 group by field1 having count(f

取两个DataTable的交集,删除重复数据

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 /// <summary>         /// 取两个DataTable的交集,删除重复数据         /// </summary>         /// <param name="sourceDataTable">源DataTable</param>         

sql查询删除重复数据

数据库UserInfo 删除重复数据 即删除重复的用户名手机号 同一个用户名手机号只保留一个用户 01.根据多个字段查询重复数据 with data1 as( select MobilePhone,Name from UserInfogroup by MobilePhone,Namehaving count(*)>1 ), 02.对重复数据分配编号 data2 as ( select u.*,row_number() over(partition by u.MobilePhone,u.Name

MySQL 处理重复数据:防止表中出现重复数据、统计、过滤、删除重复数据

MySQL 处理重复数据 有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据. 本章节我们将为大家介绍如何防止数据表出现重复数据及如何删除数据表中的重复数据. 防止表中出现重复数据 你可以在 MySQL 数据表中设置指定的字段为 PRIMARY KEY(主键) 或者 UNIQUE(唯一) 索引来保证数据的唯一性. 让我们尝试一个实例:下表中无索引及主键,所以该表允许出现多条重复记录. CREATE TABLE person_tbl

Mysql开发技巧之删除重复数据

Mysql利用联表查询和分组来删除重复数据 //删除表中重复的id,保留最大的id mysql> select * from user; +----+------+ | id | name | +----+------+ | 1 | a | | 2 | b | | 3 | c | | 4 | d | | 5 | a | | 6 | a | | 7 | c | | 8 | d | +----+------+ 8 rows in set (0.08 sec) mysql> delete a fro

Oracle删除重复数据的几种常用方法

1.有可区分的主键,其他数据相同 select * from 表名 dl where dl.id not in (select min(d.id) from  表名 d group by 重复列) 2.重复数据只能通过RowNum.RowId区分的数据 select * from 表名 where rowid in(select max(rowid) from  表名 d group by d.id,d.wareh_id,d.wareh_name having count(wareh_id)>1

oracle 查看删除重复数据

1.查询重复数据select * from 表名 where 重复字段(一般为主键)in (select 重复字段 from 表名 group by 重复字段 having count(WF_OID)>1) Select 重复字段,Count(*) From表名 Group By 重复字段 Having Count(*) > 1 2.删除重复数据DELETE from 表名 WHERE (id) IN ( SELECT 重复字段 FROM 表名 GROUP BY 重复字段HAVING COUN