NIEJIANWEI7 2010-10-25 18:48
浏览 178
已采纳

看看这个语句在oracle 数据库下面怎么写

各位大哥。。帮我看看这个语句在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的写法

涉及数据量大就没法用了。。
也不需要用到临时表的,序列的。。

  • 写回答

1条回答 默认 最新

  • 勤劳的小猿 2010-10-25 21:31
    关注

    我建了一个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)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
  • ¥15 C# datagridview 单元格显示进度及值
  • ¥15 thinkphp6配合social login单点登录问题
  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 虚心请教几个问题,小生先有礼了
  • ¥30 截图中的mathematics程序转换成matlab