Chinaunix首页 | 论坛 | 博客
  • 博客访问: 127791
  • 博文数量: 19
  • 博客积分: 35
  • 博客等级: 民兵
  • 技术积分: 100
  • 用 户 组: 普通用户
  • 注册时间: 2010-09-26 15:45
文章分类

全部博文(19)

文章存档

2016年(4)

2015年(13)

2014年(1)

2011年(1)

我的朋友

分类: Mysql/postgreSQL

2015-09-25 18:11:28

例如,id 为主键,a 列有重复数据,想要删除 重复的a,即a相同的只保留一行,可以试试如下查询:

select * from test where id not in (select max(id) from test group by a);

把 select * 换成 delete 就是删除了



mysql> select * from test;
+------+------+------+------+
| id   | a    | b    | c    |
+------+------+------+------+
|    1 |    1 |    1 |    1 |
|    2 |    1 |    2 |    2 |
|    3 |    2 |    2 |    2 |
|    4 |    3 |    3 |    3 |
|    5 |    3 |    5 |    5 |
|    6 |    3 |    6 |    6 |
+------+------+------+------+
6 rows in set (0.12 sec)

mysql> select * from test where id not in (select max(id) from test group by a);
+------+------+------+------+
| id   | a    | b    | c    |
+------+------+------+------+
|    1 |    1 |    1 |    1 |
|    4 |    3 |    3 |    3 |
|    5 |    3 |    5 |    5 |
+------+------+------+------+
3 rows in set (0.12 sec)

mysql>

阅读(1850) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~