首页 > 数据库技术 > 详细

MYSQL 当有两条重复数据时 保留一条

时间:2015-08-19 19:25:34      阅读:270      评论:0      收藏:0      [点我收藏+]
delete from test  where id in (select id from (select  max(id) as id,count(text) as count from test group by text having count >1 order by count desc) as tab )


测试代码


 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘22222‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘22222‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘22222‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘22222‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘22222‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘1111‘,‘33333‘);

 INSERT IGNORE INTO test_1(text,text2) values (‘22222‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘22222‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘22222‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘22222‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘22222‘,‘33333‘);
 INSERT IGNORE INTO test_1(text,text2) values (‘22222‘,‘33333‘);


 REPLACE  INTO test(text) values (‘1111‘)

delete from test

select * from test_1 where text=‘1111‘
select * from test_1 where text=‘22222‘

while 
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );

delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );
delete from test_1  where id in (select id from (select  max(id) as id,count(text) as count from test_1 where text = ‘22222‘ group by text,text2 having count >1 order by count desc) as tab );





MYSQL 当有两条重复数据时 保留一条

原文:http://www.cnblogs.com/yilongm/p/4742875.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!