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

2023-12-04 0 569

这是sql

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

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

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

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

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

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

select * from
( select rownum id,t1.* from
(select t2.* from t2 order by t2.某列)
t1)
where id=第几条;

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

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

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

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

where id=第几条

写成

where id = 5

就好了。

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

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

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

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

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

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数据库如何获取多条结果集中的第一条或某一条的文章就介绍到这了,更多相关Orcale获取多条结果集中某一条内容请搜索悠久资源以前的文章或继续浏览下面的相关文章希望大家以后多多支持悠久资源!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 Oracle Oracle数据库如何获取多条结果集中的第一条或某一条 https://www.u-9.cn/database/oracle/67271.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务