上海腾科教育达梦数据库培训干货分享ROWNUM在达梦数据库中的使用

ROWNUM 是一个虚假的列,表示从表中查询的行号,或者连接查询的结果集行数。它将被分配为 1,2,3,4,..N,N 是行的数量。通过使用ROWNUM ,我们可以限制查询返回的行数。

 

我们以实例库BOOKSHOP中RESOURCES模式下EMPLOYEE表为例

该表的完整数据如下:

 

 

如果我们只想看到前 5 行数据,可以这样写

SELECT * FROM RESOURCES.EMPLOYEE WHERE rownum < 6;

 

 

需要注意的是,一个 ROWNUM 值不是被永久的分配给一行。表中的某一行并没有标号,不可以查询ROWNUM值为 5 的行。ROWNUM 值只有当被分配之后才会增长,并且初始值为 1。即只有满足一行后,ROWNUM 值才会加 1,否则只会维持原值不变。因此,以下语句在任何时候都不能返回数据。

 

SELECT * FROM RESOURCES.EMPLOYEE WHERE ROWNUM > 6;

SELECT * FROM RESOURCES.EMPLOYEE WHERE ROWNUM = 6;

 

 

ROWNUM 一个重要作用是控制返回结果集的规模,可以避免查询在磁盘中排序。因为,ROWNUM 值的分配是在查询的谓词解析之后,任何排序和聚合之前进行的。因此,在排序和聚合使用 ROWNUM 时需要注意,可能得到并非预期的结果,例如假如我们想得到员工年龄最大的五个人

SELECT * FROM RESOURCES.EMPLOYEE WHERE ROWNUM < 6ORDER BY BIRTHDATE;

 

 

以上语句只会对 EMPLOYEE 表前 5 行数据按 BIRTHDATE排序输出,并不是表的所有数据按BIRTHDATE 排序后输出前 5行,要实现后者,需要使用如下语句:

SELECT * FROM (SELECT * FROM RESOURCES.EMPLOYEE ORDER BY BIRTHDATE)WHERE ROWNUM < 6;

或者SELECT TOP 5 * FROM RESOURCES.EMPLOYEE ORDER BY BIRTHDATE;

结果如下:

 

 

关于ROWNUM的使用,还需注意以下的限制:

1. 在查询中,ROWNUM 可与任何数字类型表达式进行比较及运算,但不能出现在含OR 的布尔表达式中,否则报错处理;

 

2. ROWNUM 只能在非相关子查询中出现,不能在相关子查询中使用,否则报错处理;

 

3. 在非相关子查询中,ROWNUM 只能实现与 TOP 相同的功能,因此子查询不能含ORDER BY 和 GROUP BY;

 

4.ROWNUM 所处的子谓词只能为如下形式: ROWNUM op exp,exp 的类型只能是立即数、参数和变量值,op ∈ {<, <=, >, >=, =,<>}。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值