日期:2014-05-17  浏览次数:20844 次

这个SQL怎么写啊?
有一个表   a   ,有如下数据

id     type     time
1           a       20070605
2           b       20070606
3           b       20070530
4           a       20070610
5           c       20070609
6           a       20070608
7           b       20070601
8           a       20070602
9           c       20070612
10         c       20070623

请问如何获得的每个   type   按时间desc排序的前2项啊??是每个   type   都返回2项.

就是返回结果如下:

id       type     time
4           a       20070610
6           a       20070608
2           b       20070606
7           b       20070601
10         c       20070623
9           c       20070612

在线等.

------解决方案--------------------
select *
from (select t.*,
count(*) over(partition by type order by time desc) as cnt
from a t) tt
where tt.cnt <= 2
------解决方案--------------------
create table test2(id int, type varchar2(10), time varchar2(100));

insert into test2
select 1, 'a ', '20070605 ' from dual
union all
select 2, 'b ', '20070606 ' from dual
union all
select 3, 'b ', '20070530 ' from dual
union all
select 4, 'a ', '20070610 ' from dual
union all
select 5, 'c ', '20070609 ' from dual
union all
select 6, 'a ', '20070608 ' from dual
union all
select 7, 'b ', '20070601 ' from dual
union all
select 8, 'a ', '20070602 ' from dual
union all
select 9, 'c ', '20070612 ' from dual
union all
select 10, 'c ', '20070623 ' from dual
--执行sql
select id,type,time from
(select id,type,time,row_number()over(partition by type order by time desc) inx from test2) t
where t.inx <=2
--Result
1 4 a 20070610
2 6 a 20070608
3 2 b 20070606
4 7 b 20070601
5 10 c 20070623
6 9 c 20070612