您的位置:首页 > 数据库 > MySQL

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

2015-08-19 17:31 591 查看
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 );

来自为知笔记(Wiz)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: