SQL實現分組limit

孤竹星發表於2017-02-16
mysql> create table a (id int,fid int ,name varchar(10));
Query OK, 0 rows affected (0.10 sec)

mysql> insert into a value (1,1,'a');
Query OK, 1 row affected (0.04 sec)

mysql> insert into a value (2,1,'b');
Query OK, 1 row affected (0.01 sec)

mysql> insert into a value (3,1,'c'); 
Query OK, 1 row affected (0.01 sec)

mysql> insert into a value (4,2,'d');   
Query OK, 1 row affected (0.02 sec)

mysql> insert into a value (5,2,'e'); 
Query OK, 1 row affected (0.01 sec)

mysql> insert into a value (6,2,'f'); 
Query OK, 1 row affected (0.00 sec)

 mysql> select * from a
    -> ;
+------+------+------+
| id   | fid  | name |
+------+------+------+
|    1 |    1 | a    |
|    2 |    1 | b    |
|    3 |    1 | c    |
|    4 |    2 | d    |
|    5 |    2 | e    |
|    6 |    2 | f    |
+------+------+------+
6 rows in set (0.00 sec)
mysql> select * from a where 2>( select count(*) from a b  where a.fid=b.fid and a.id<b.id )order by fid ;
+------+------+------+
| id   | fid  | name |
+------+------+------+
|    2 |    1 | b    |
|    3 |    1 | c    |
|    5 |    2 | e    |
|    6 |    2 | f    |
+------+------+------+
4 rows in set (0.00 sec)


mysql> select * from a where 2>( select count(*) from a b  where a.fid=b.fid and a.id>b.id )order by fid ;
+------+------+------+
| id   | fid  | name |
+------+------+------+
|    1 |    1 | a    |
|    2 |    1 | b    |
|    4 |    2 | d    |
|    5 |    2 | e    |
+------+------+------+
4 rows in set (0.00 sec)

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28282660/viewspace-2133644/,如需轉載,請註明出處,否則將追究法律責任。

相關文章