广告位联系
返回顶部
分享到

Oracle数据库如何获取多条结果集中的第一条或某一条

oracle 来源:互联网 作者:佚名 发布时间:2023-03-12 17:01:58 人浏览
摘要

这是sql 1 2 3 4 5 6 --获取多条结果集中的第一条,通常会排下序之类的,随你方便,如果你不排序直接用括号里的就行 select * from (select * from table where 1 = 1 order by value1) where rownum = 1; 这里

这是sql

1

2

3

4

5

6

--获取多条结果集中的第一条,通常会排下序之类的,随你方便,如果你不排序直接用括号里的就行

select * from

    (select * from table

     where 1 = 1

     order by value1)

where rownum = 1;

这里解释一下,为什么外边要多套一层select,我猜你写的sql应该是

1

select * from table where rownum = 1 order by value1;

但是你取到的应该不是你order by出来的第一条,因为sql执行顺序并不是真的从后往前读,代码会先读 where而不是 order by ,所以where rownum = 1的时候,实际上它就查出来一条,所以order by虽然执行了,但并不是把结果集 order by 之后才抽出第一条。

那么怎么选择结果集的其他条呢?

其实没有找到太好的办法,只能参考以下了

1

2

3

4

5

select * from

    ( select rownum id,t1.* from

         (select t2.* from t2 order by t2.某列)

    t1)

where id=第几条;

看起来很多层是吧,不要害怕,我一说你就懂了。

最里层的 t2 是用来把你想要的数据进行排序,

外一层的 t1 是用来给你排好序的数据加一列序号ID,

最外层的就是获取你想要的某一条了,比如结果集有10条,你想要的第5条,那么 就把

1

where id=第几条

写成

1

where id = 5

就好了。

补充:Oracle分组取第一条数据

看看以前的私密日志,原来自己之前被很多小而简单的问题困惑过!

看着那时候我们还是新手中的新手做的备忘笔记!

其实就是用了Oracle的统计函数而已!
以前的日记(看样子应该是以前公司的源码,呵呵……)如下:勿喷!

对多数据进行分组排序后取每组第一条记录:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

SELECT *

  FROM (

       SELECT ROW_NUMBER() OVER(

       PARTITION BY  ZA40011_3.URIAGE_DENPYO_NO,ZA40011_3.URIAGE_DENPYO_ROW_NO 

       ORDER BY  ZA40011_3.KAKUTEI_SURYO_CS,

                  ZA40011_3.KAKUTEI_SURYO_BL,

                  ZA40011_3.KAKUTEI_SURYO_BT,

                  ZA40011_3.SYUKKA_SHIJI_NO,

                  ZA40011_3.SYUKKA_SHIJI_ROW_NO  DESC) LEV,

                ZA40011_3 .*

       FROM  WT_001_ZA40011_22070_2 ZA40011_2,

             WT_001_ZA40011_22070_3 ZA40011_3,

             JT_GYOMU_URIAGE_DETAIL URIAGE_DETAIL

       WHERE

       ZA40011_2.KAISYA_CODE = URIAGE_DETAIL.KAISYA_CODE

           AND ZA40011_2.URIAGE_DENPYO_NO = URIAGE_DETAIL.URIAGE_DENPYO_NO

           AND ZA40011_2.URIAGE_DENPYO_ROW_NO = URIAGE_DETAIL.ROW_NO

           AND URIAGE_DETAIL.KAISYA_CODE = ZA40011_3.KAISYA_CODE

           AND URIAGE_DETAIL.URIAGE_DENPYO_NO = ZA40011_3.URIAGE_DENPYO_NO

           AND URIAGE_DETAIL.ROW_NO = ZA40011_3.URIAGE_DENPYO_ROW_NO

           AND ZA40011_3.KEPPIN_RIYU_CODE IS NOT NULL

        )

 WHERE LEV = 1

-- ORDER BY KAKUTEI_SURYO_CS DESC


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/cantclimbthetree/article/details/123956896
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计