news 2026/6/15 15:34:15

oracle到瀚高rownum替换问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
oracle到瀚高rownum替换问题

文章目录

  • 文档用途
  • 详细信息

文档用途

当我们做数据迁移或者应用迁移时,遇到分页的问题是必不可少的,那么Oracle中我们用到rownum来限制显示的行数,在瀚高里面,我们用limit和offset字句限制只取出查询结果的部分行。

如果给出了一个 LIMIT 计数,那么将返回不超过该数字的行(也可能更少些,因为可能查询本身生成的总行数就比较少)。LIMIT ALL和省略 LIMIT子句是一样的。

OFFSET指明在开始返回行之前忽略多少行。OFFSET 0和省略 OFFSET和LIMIT NULL 子句是一样的。如果 OFFSET和 LIMIT 都出现了,那么在计算OFFSET之前先忽略 LIMIT指定的行数。

那么这个转换是如何实现的?详情信息就在下面。

详细信息

rownum替换的问题
(1)大于等于的情况:

删除rownum>=row , 其中row可能是数字或者参数或者函数

<1>select * from test where rownum >= to_number(i_start) ;

转换为

select * from test ;

<2>select * from test where rownum >= to_number(i_start) and rownum <= 10 ;

转换为

select * from test limit 10;

<3>select * from test where ID>10 and rownum >= to_number(i_start);

转换为

select * from test where ID>10 ;

<4>select * from test where rownum >= to_number(i_start) and ID>10 ;

转换为

select * from test where ID>10 ;

(2)没有大于等于的情况:

A)where之后的,限制查询出来的条数(rownum <=number 或者 rownum = 1)

<1>select * from test where rownum <=10 (条件只有rownum)

转换为select * from test limit 10

<2>select * from test where rownum <=10 and ID >5 (有其他条件rownum前边是where)

转换为select * from test where ID >5 limit 10

<3>select * from test where ID >5 and rownum <=10 (有其他条件rownum前边是and或or之类的)

转换为select * from test where ID >5 limit 10

<4>select * from test where ID >5 and rownum <=10 and ID <10 group by id order by id (有其他条件且rownum不在最后一个条件)

转换为select * from test where ID >5 and ID <10 group by id order by id limit 10

<5>select * from test where rownum = 1 (rownum = 1 和rownum<=1逻辑类似可以共用)

转换为select * from test limit 1

第一种只有一个rownum条件的话需要删除where后几种可以归结为一种 就是有其他条件(不限于and,可能有其他关联关键字or或者其他),这种情况需要替换rownum并放到最后(如果有group by或者order by放到它们后边)

如果连接符是<的话,做减一处理

B)select之后的,带别名(可能没有as来连接),查询序号 —> 用row_number() OVER ()来替换

<1>select rownum as row ,t.* from testrownum t ; (别名有as来连接)

转换为:select row_number() OVER () as row ,t.* from testrownum t ;

<2>select rownum row ,t.* from testrownum t ; (别名没有as来连接)

转换为:select row_number() OVER () as row ,t.* from testrownum t ;

C)select之后的,不带别名,查询序号 —> 用row_number() OVER () as rownum来替换

<1>select rownum ,t.* from testrownum t ;(没有别名)

转换为:select row_number() OVER () as rownum ,t.* from testrownum t ;

(3)在update或者delete中ROWNUM问题

<1> update test3 set id = (select id from test2 where id =1 and rownum=1 group by id ) where id = 0 and rownum=1 ;

转化成:

with cte as (select ctid from test3 where id = 0 limit 1)

update test3 set id = (select id from test2 where id =1 group by id limit 1) where ctid in (select ctid from cte) ;

<2> delete from test3 where id=0 and rownum = 1;

转换为:

with cte as (select ctid from test3 where id = 0 limit 1)

delete from test3 where ctid in (select ctid from cte) ;

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 7:26:04

P6Spy零基础入门:5分钟搞定数据库监控

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请生成一个最简单的P6Spy入门示例&#xff0c;要求&#xff1a;1. 最简Spring Boot项目 2. 清晰注释的配置说明 3. 示例SQL查询 4. 输出格式化日志。避免复杂概念&#xff0c;使用…

作者头像 李华
网站建设 2026/6/10 18:33:34

真实案例:团队协作中如何处理Git文件覆盖警告

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个团队协作Git工作流模拟器&#xff0c;模拟多人同时修改同一文件导致的冲突场景。功能包括&#xff1a;1) 创建模拟Git仓库 2) 生成多个开发者同时修改的场景 3) 触发YOUR …

作者头像 李华
网站建设 2026/6/15 14:34:26

步态识别入门实战:云端1小时搞定数据标注

步态识别入门实战&#xff1a;云端1小时搞定数据标注 引言&#xff1a;为什么医生需要步态识别技术&#xff1f; 在康复医疗领域&#xff0c;帕金森患者的步态分析是评估病情进展和治疗效果的重要指标。传统方式需要医生逐帧观看视频&#xff0c;手动标注关节位置&#xff0c…

作者头像 李华
网站建设 2026/6/13 9:26:25

【高并发系统稳定性保障】:连接池2.0自动伸缩策略全解析

第一章&#xff1a;连接池2.0架构演进与核心挑战随着微服务架构和高并发系统的普及&#xff0c;传统连接池在资源管理、响应延迟和弹性伸缩方面逐渐暴露出瓶颈。连接池2.0应运而生&#xff0c;其核心目标是实现更智能的连接调度、更低的资源开销以及更强的可观测性。动态连接生…

作者头像 李华
网站建设 2026/6/12 10:25:58

30分钟构建JVM参数检查工具原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个最小可行产品(MVP)包含&#xff1a;1. 日志文件上传接口 2. 关键参数识别引擎 3. 简单结果展示页面 4. 导出建议功能。使用Python Flask框架&#xff0c;无需复杂UI&#…

作者头像 李华