mysql如何删除重复数据并保留ID最大的数据

题:有一张test表,里面含有三个字段id,name,sex。

问:如何查询重复数据?

select name,sex,count(*) from test group by name,sex HAVING count(*)>1。

问:如何删除重复数据并保留ID最大的数据?

delete a from test a join

(select name,sex,count(*) ,max(id) as id

from test group by name,sex

HAVING count(*)>1) b on a.name=b.name where a.id<b.id

时间: 2024-11-10 01:06:33

mysql如何删除重复数据并保留ID最大的数据的相关文章

Mysql删除重复记录,保留id最小的一条

mysql 查询重复字段,及删除重复记录的方法MySQL, 数据库, 数据库, 字段, 服务器数据库中有个大表,需要查找其中的名字有重复的记录id,以便比较.如果仅仅是查找数据库中name不重复的字段,很容易:SELECT min(`id`),`name` FROM `table` GROUP BY `name`; 但是这样并不能得到说有重复字段的id值.(只得到了最小的一个id值)查询哪些字段是重复的也容易:SELECT `name`,count(`name`) as count FROM `

sql 多个字段分组,删除重复记录,保留ID最小的一条

IF OBJECT_ID('cardDetail') IS NOT NULL DROP TABLE cardDetail CREATE TABLE cardDetail ( id INT IDENTITY(1,1) PRIMARY KEY, cardNO VARCHAR(8), NAME VARCHAR(30), idCard VARCHAR(18), cardState CHAR(1)--卡片状态 1正常 2注销 ) INSERT cardDetail(cardNO,NAME,idCard,c

删除重复项,只保留id最小的一项

DELETE FROM spider_927 WHERE 1=1 AND title in (SELECT * FROM ( (SELECT title titles FROM spider_927 GROUP BY title HAVING COUNT(title)>1) ) a) AND id not in (SELECT * FROM ( (SELECT MIN(id) ids FROM spider_927 GROUP BY title HAVING COUNT(title)>1) )

EXCEL 删除重复项并保留最大最小值

自定义排序 框选需要主次排序的区域 开始-排序和筛选-自定义排序 添加筛选条件 若要获取最小值则次要关键字选择升序 排序后的数据 删除重复项 数据-删除重复项 选择要删除的列 删除A列的重复项后,B列留下了最小值 EXCEL 删除重复项并保留最大最小值,布布扣,bubuko.com

mysql 存储过程 删除重复

DELIMITER $$ CREATE PROCEDURE `delRepeatCA`() BEGIN DECLARE tally INT DEFAULT 0; SELECT COUNT(rs.c_CA) INTO tally FROM          --------赋值 (SELECT COUNT(c_CA) AS c_CA FROM t_CA GROUP BY c_CA HAVING COUNT(1) > 1) rs WHILE tally>0 DO --------循环 IF(tal

MYSQL 删除重复记录,只保留最大ID

table : productprice table column : id ,productAsin ... 同一个productAsin 只保留最近的那条,即只保留ID 最大的. 第一步: 查出有重复的记录和最大的id SELECT productAsin,MAX(id) maxId FROM productprice GROUP BY productAsin HAVING COUNT(id) >= 2)tempt 第二步:查出在重复记录的,并且小于最大的id SELECT productp

删除重复数据,只保留ID最小的一条数据

最近遇到一个问题,就是使用的rm_user_department的重复数据过多,需要删除重复数据,在网上找的sql,照着写的基本上运行都有错误,现在将自己写的贴出来给大家看看. rm_user_department 的表结构如图: select * from rm_user_department DELETE FROM rm_user_department --这里不能使用别名,如果使用别名会报错 WHERE ( user_id, dep_id, user_type ) IN ( select

Mysql 中删除重复数据(保留一条)

sql去重 先根据需要去重的字段进行分组,取到主键值最小的记录(id 是主键,删除重复的 record_id 的记录) select min(id) from tb_traffic_wf_record t group by t.record_id 然后删除不在上面的记录里的数据,就行了 delete from tb_traffic_wf_record where id not in (select min(id) from tb_traffic_wf_record as t group by t

MySQL中删除重复数据只保留一条

用SQL语句,删除掉重复项只保留一条 在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 SELECT * FROM people WHERE peopleId IN ( SELECT peopleId FROM people GROUP BY peopleId HAVINGcount(peopleId) > 1 ) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 1 2 3