各位大哥。。帮我看看这个语句在oracle 数据库下面怎么写
ID value
1 13
1 15
1 98
2 90
2 6767
2 898
2 6760
3 11
3 778
3 998
3 567
我想查出每类ID 的value最小的前2条数据
比如说
ID VALUE
1 13
1 15
2 90
2 898
3 11
3 567
语句怎么写啊?
不要用minus的写法
涉及数据量大就没法用了。。
也不需要用到临时表的,序列的。。
我建了一个a表:有一个两个字段。
idx val
1 1
1 12
1 3
2 33
2 31
2 5
语句:
[code="sql"]
select t.idx,t.val from (select idx,val, row_number() over (partition by idx order by val asc) as num from a) t where num <3;
[/code]
结果是:
idx val
1 1
1 3
2 5
2 31
是你要的结果吧。
row_number() over (partition by idx(注释:这写的是要分组的字段) order by val(这写的是要排序的字段) asc)