这样的sql语句你会怎么写?

有这样一个表,数据是这样的
| id | name |
+------+------+
| 1 | a |
| 1 | b |
| 1 | c |
| 2 | d |
| 2 | e |


通过分组查询可以得到这样的结果
select count(id) from a group by id;
+-----------+
| count(id) |
+-----------+
| 3 |
| 2 |
+-----------+

现在的要求是我想分组统计相同id的值出现过次数>2次的记录。
比如上面:
| 2 | d |
| 2 | e |

这样记录应该舍去,如果是你,你会怎么写SQL语句?

作者: qxh0724   发布时间: 2011-05-24

SQL code
select * from 有这样一个表 a
where 2<(select count(*) from 有这样一个表 where id=a.id)

作者: ACMAIN_CHM   发布时间: 2011-05-24