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)
测试代码
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)
相关文章推荐
- MySQL数据库备份
- MySQL在创建索引之前一定要想到的事情
- MySQLDump在使用之前一定要想到的事情
- 黄聪:mysql 存在该记录则更新,不存在则插入记录的sql
- 开源数据库中间件 Vitess:一组旨在使 web 应用的 MySql 数据库的水平扩展简单化的服务器和工具集
- 开源数据库中间件 Vitess:一组旨在使 web 应用的 MySql 数据库的水平扩展简单化的服务器和工具集
- MySQL基础知识点
- MYSQL数据表损坏的原因分析和修复
- mysql字符串转化数字排序
- mysql 创建用户分配只读权限
- mysql内核,开源中国送的书已经收到,感谢组织!
- mysql基本内容学习过程
- MySQL ODBC创建
- MySQL零碎知识整理
- mysql :转义字符
- Power Designer逆向操作(从mysql5.0生成数据库的物理模型)
- mysql基础
- MYSQL手工注入入门示例
- 允许主机远程管理mysql数据库
- MySQL 5.5 和 5.6 默认参数值的差异