时间:2023-10-31来源:系统城装机大师作者:佚名
这是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 |
总结
到此这篇关于Orcale数据库如何获取多条结果集中的第一条或某一条的文章就介绍到这了
2023-10-31
Oracle如何编写一个sqlldr实例2023-10-31
Oracle的SQLLDR用法简介2023-10-31
Oracle中的高效SQL编写PARALLEL解析1.Oracle数据库系统结构概述 2.Oracle数据库存储结构 物理存储结构 控制文件 数据文件 重做日志文件 归档日志文件 Oracle数据库逻辑结构 数据块(Data Block) (盘)区(Extent) 段(Segment) 表空间(Tablespace) 本地管...
2023-10-31
windows下的Oracle19c 一、官网下载Oracle19c数据库 二、安装Oracle数据库 1.解压安装包 2.运行setup.exe安装 三、配置 四、安装完Oracle数据库,给scott用户解锁 1.解决Oracle数据库中没有scott账户的问题 2.给scott...
2023-10-31