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

MYSQL
MySQL用户管理
Mysql字段长度
如何为用户设置密码(MYSQL)
MySQL数据库备份
MYSQL初学者使用指南 上篇
MYSQL初学者使用指南 下篇
修改MySQL中一个用户的密码
Linux下mSQL数据库开发技术
MySQL进阶_SELECT篇(一)
MySQL进阶_SELECT篇(二)
MySQL 的邮件列表
MySQL中的SQL-- TEXT、DATE、和SET数据类型
谈谈数据从sql server数据库导入mysql数据库的体验
使用MySql ODBC进行MYsql和MS sql7的数据转换
MySQL服务维护笔记 续
MySQL 如何对抗解密高手
MySQL常见错误问答!
MySQL 5.0 触发器
MySQL 如何从表中取出随机数据
mysql的日期和时间函数

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 91 ::
收藏到网摘: 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;