在ORACLE中实现SELECT TOP N的方法

本文介绍在Oracle数据库中如何实现TOPN查询,包括选取指定数量的记录、特定位置的记录及范围内的记录。通过实例展示了使用ROWNUM进行排序和筛选的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.ORACLE实现SELECT TOP N

由于ORACLE不支持SELECT TOP句,所以在ORACLE常是用ORDER BYROWNUM合来实现SELECT TOP N查询

简单实现方法如下所示:

SELECT 列名1...列名n FROM

(SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N(抽出记录数)

ORDER BY ROWNUM ASC

下面个例子简单说明一下。

客表customer(id,name)有如下数据:

ID NAME

01 first

02 Second

03 third

04 forth

05 fifth

06 sixth

07 seventh

08 eighth

09 ninth

10 tenth

11 last

NAME的字母抽出前三个客的SQL句如下所示:

SELECT * FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= 3

ORDER BY ROWNUM ASC

ID NAME

08 eighth

05 fifth

01 first

2.TOP N纪录中抽出第MM <= N)条记录

在得到了TOP N的数据之后,了抽出N记录中的第M记录,我可以考ROWNUM着手。知道,ROWNUM记录表中数据号的一个藏子段,所以可以在得到TOP N记录候同抽出记录ROWNUM,然后再从N记录中抽取记录编M记录,即是我希望得到的果。

从上面的分析可以很容易得到下面的SQL句。

SELECT 列名1...列名n FROM

(

SELECT ROWNUM RECNO, 列名1...列名nFROM

(SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N(抽出记录数)

ORDER BY ROWNUM ASC

)

WHERE RECNO = MM <= N

以上表的数据,那得到以NAME的字母排序的第二个客的信息的SQL应该这样写:

SELECT ID, NAME FROM

(

SELECT ROWNUM RECNO, ID, NAME FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= 3

ORDER BY ROWNUM ASC )

WHERE RECNO = 2

则为

ID NAME

05 fifth

3.抽出按某方式排序的记录集中的第N记录

2明中,当M = N候,即标题3所讲果。实际上,2的做法在里面N>M的部分的数据是基本上不会用到的,我们仅仅明方便而采用。

如上所述,SQL应为

SELECT 列名1...列名n FROM

(

SELECT ROWNUM RECNO, 列名1...列名nFROM

(SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N(抽出记录数)

ORDER BY ROWNUM ASC

)

WHERE RECNO = N

2中的例子的SQL则为

SELECT ID, NAME FROM

(

SELECT ROWNUM RECNO, ID, NAME FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= 2

ORDER BY ROWNUM ASC

)

WHERE RECNO = 2

ID NAME

05 fifth

4.抽出按某方式排序的记录集中的第M记录开始的X记录

3里所仅仅是抽取一条记录的情况,当我需要抽取多条记录候,此2中的N的取值应该是在N >= (M + X - 1)个范内,当然经济的取就是取等号候了。当然最后的抽取条件也不是RECNO = N了,应该RECNO BETWEEN M AND (M + X - 1)了,所以随之而来的SQL则为

SELECT 列名1...列名n FROM

(

SELECT ROWNUM RECNO, 列名1...列名nFROM

(

SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n)

WHERE ROWNUM <= N N >= (M + X - 1)

ORDER BY ROWNUM ASC

)

WHERE RECNO BETWEEN M AND (M + X - 1)

以上面的数据例,抽取NAME的字母的第2记录开始的3记录SQL

SELECT ID, NAME FROM

(

SELECT ROWNUM RECNO, ID, NAME FROM

(SELECT * FROM CUSTOMER ORDER BY NAME)

WHERE ROWNUM <= (2 + 3 - 1)

ORDER BY ROWNUM ASC

)

WHERE RECNO BETWEEN 2 AND (2 + 3 - 1)

果如下:

ID NAME

05 fifth

01 first

04 forth

以此,再展的,做成存储过程,将记录数以及抽取记录参数,就可以实现抽取数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值