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

 更新时间:2023年03月09日 11:25:22   作者:不会爬树  
Oracle从多条符合条件的记录中选择一条这个需求相信大家应该都遇到过,这篇文章主要给大家介绍了关于Oracle数据库如何获取多条结果集中的第一条或某一条的相关资料,需要的朋友可以参考下

这是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获取多条结果集中某一条内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle分组函数之ROLLUP的基本用法

    Oracle分组函数之ROLLUP的基本用法

    这篇文章主要给大家介绍了关于Oracle分组函数之ROLLUP的基本用法,文中通过示例代码介绍的非常详细,对大家学习或者使用Oracle数据库具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • Oracle数据库迁移所有文件到新挂载磁盘路径

    Oracle数据库迁移所有文件到新挂载磁盘路径

    根据实际须要,有时安装了oracle以后须要扩展磁盘空间时,每每是新增一个单独的文件路径并挂载存储,这时便须要总体迁移数据库文件数据库,本文就来介绍一下Oracle数据库迁移所有文件到新挂载磁盘路径
    2024-01-01
  • 基于oracle小数点前零丢失的问题分析

    基于oracle小数点前零丢失的问题分析

    本篇文章是对oracle小数点前零丢失的问题进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Oracle中游标Cursor的用法详解

    Oracle中游标Cursor的用法详解

    本文详细讲解了Oracle中游标Cursor的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle 中 row_number()、rank()、dense_rank() 函数的用法详解

    Oracle 中 row_number()、rank()、dense_rank() 函数的

    rank() 与 row_number() 的区别在于,rank() 会按照排序值相同的为一个序号(以下称为:块),第二个不同排序值将显示所有行的递增值,而不是当前序号加1,下面通过示例介绍下Oracle 中 row_number()、rank()、dense_rank() 函数的用法,一起看看吧
    2024-03-03
  • C#连接ORACLE出现乱码问题的解决方法

    C#连接ORACLE出现乱码问题的解决方法

    最近接触c#的一个项目,连接SqlServer数据库倒也是很好用,但是遇到oracle数据库就出现乱码了,于是搜索好多资料,具体解决方法如下
    2021-10-10
  • Oracle解锁表、包、用户、杀会话、停job的方法实现

    Oracle解锁表、包、用户、杀会话、停job的方法实现

    本文主要介绍了Oracle解锁表、包、用户、杀会话、停job的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • Oracle SQL Developer显示的时间包含时分秒的设置方法

    Oracle SQL Developer显示的时间包含时分秒的设置方法

    Oracle SQL Developer是Oracle公司出品的一个免费的集成开发环境,本篇文章给大家介绍Oracle SQL Developer显示的时间包含时分秒的设置方法,需要的朋友参考下吧
    2015-09-09
  • Oracle临时表空间删除和重建实现过程

    Oracle临时表空间删除和重建实现过程

    这篇文章主要介绍了Oracle临时表空间删除和重建实现过程,临时表空间是NOLOGGING模式以及它不保存永久类型对象,因此即使数据库损毁,做Recovery也不需要恢复Temporary Tablespace。下文更多详细内容介绍需要的小伙伴可以参考一下
    2022-03-03
  • Oracle的数据字典技术简析

    Oracle的数据字典技术简析

    Oracle的数据字典技术简析...
    2007-03-03

最新评论