当前位置: 首页 > 图文教程 > 数据库 > MYSQL > mysql删除表中某一字段重复的记录

MYSQL
MySQL 一次执行多条语句的实现及常见问题
mysql 常见命令和学习心得
mysql 发生系统错误1067的解决方法
MySQL 建表的优化策略 小结
批量替换 MySQL 指定字段中的字符串
mysql4.0升级到mysql5(4.1),解决字符集问题
MySQL 随机密码生成代码
Linux系统下配置功能完善的Web服务器
PHP+MYSQL实例:网站在线人数的代码
Perl直接入门详尽指南
PHP实例程序:直接读取数据库信息的三种方法
Apache、PHP和mySQL的配置的过程
新手学PHP和MySQL动态网站开发教程
优化mysql性能的十个参数
用相关数据库命令对MySQL进行优化
MYSQL执行SQL语句需要注意的两个问题
保护MySQL数据库中重要数据全攻略
Linux下配置 Tomcat+JDK+MySQL应用平台
数据从MySQL迁移到 Oracle的注意事项
快速掌握 MySQL数据库中触发器的应用

MYSQL 中的 mysql删除表中某一字段重复的记录


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 87 ::
收藏到网摘: n/a

一般大家也许会碰到这个问题,大家可以参考下,讲的比较详细

比如,表:event(id int(10) auto_increment primary key,
sid int(10)not null,
detail text)

我想删除表event中sid重复的记录,请问有没有这样SQL语句?或是通过其它方法?

复制代码 代码如下:

delete from event as e
where id != (select min(id) from event where sid=e.sid);

or
复制代码 代码如下:

delete from event
where sid not in (select mid from (select sid ,min(id) as mid from event group by sid))

应该是有用的代码
复制代码 代码如下:

alter ignore table event add unique index idu_sid (sid);
alter table event drop index idu_sid;