news 2026/4/18 1:47:01

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/4/18 0:35:46

Python注释完全指南:从零开始学代码文档

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请创建一个Python新手学习注释的教程代码文件&#xff0c;包含以下内容&#xff1a; 1. 单行注释的例子 2. 多行注释的例子 3. 函数文档字符串的例子 4. 类文档字符串的例子 5. 模…

作者头像 李华
网站建设 2026/4/18 0:01:09

小白玩转Z-Image-ComfyUI:不懂代码也能用,1小时1块钱

小白玩转Z-Image-ComfyUI&#xff1a;不懂代码也能用&#xff0c;1小时1块钱 引言&#xff1a;退休教师的AI绘画初体验 最近有位退休教师王阿姨找到我&#xff0c;说看到朋友圈里有人用AI生成山水画特别漂亮&#xff0c;自己也想试试。但一听说要装软件、配环境就头疼——&qu…

作者头像 李华
网站建设 2026/4/17 19:21:31

骨骼点检测数据标注捷径:预标注+人工校验,效率提升5倍

骨骼点检测数据标注捷径&#xff1a;预标注人工校验&#xff0c;效率提升5倍 1. 为什么骨骼点标注让创业团队头疼 作为计算机视觉领域的基础任务&#xff0c;骨骼点检测需要标注大量人体关键部位坐标&#xff08;如头、颈、肩、肘、膝等&#xff09;。传统纯人工标注方式面临…

作者头像 李华
网站建设 2026/4/16 14:29:51

3步快速修复预览处理器崩溃 - 效率提升指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个极简的Windows错误修复工具&#xff0c;专注于快速解决PREVIEW HANDLER SURROGATE HOST问题。要求&#xff1a;1. 单文件绿色版程序&#xff1b;2. 三步操作完成修复(检测…

作者头像 李华
网站建设 2026/4/15 16:30:25

ThrottleStop实战:解决游戏本过热降频问题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个分步指南应用&#xff0c;演示如何为特定游戏本型号&#xff08;如联想拯救者Y7000&#xff09;配置ThrottleStop解决过热降频问题。包含温度监控、电压调整、性能测试等完…

作者头像 李华
网站建设 2026/4/16 13:01:44

1小时用Electron打造产品原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 快速开发一个Electron截图工具原型&#xff0c;功能包括&#xff1a;1) 全屏/区域截图选择 2) 简单标注工具&#xff08;矩形、箭头、文字&#xff09;3) 保存到本地或复制到剪贴板…

作者头像 李华