Oracle中rownum的疑问

原始数据:
 

-- 创建表
CREATE TABLE TEST_1 
( T INT primary key);

-- 插入数据
CREATE OR REPLACE PROCEDURE PRO_1 AS
BEGIN
    FOR I IN 1 .. 10000 LOOP
        EXECUTE IMMEDIATE 'INSERT INTO TEST_1 VALUES (:I)' USING I;
    END LOOP;
END;

BEGIN
    PRO_1;
END;


当我使用rownum的时候发现,在有where子句的时候,select的结果符合预期:

SELECT T,ROWNUM N1 FROM TEST_1 WHERE ROWNUM < 10 ORDER BY T;


但是如果不适用where子句,则:

SELECT T,ROWNUM N1 FROM TEST_1 ORDER BY T;


请问这是什么情况呢?

rownum不是从1开始的

你把表truncate掉,然后插入数据,再执行,你就能理解了。

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y

明白了,是order by 和rownum 执行顺序的问题。