Oracle数据库的CONNECT BY ROWNUM研究

CONNECT BY ROWNUM

实验

select id from test;

结果:

id

1

2

3

4

5

SELECT ROWNUM,id                                                      
FROM
test
CONNECT BY ROWNUM <= 1;

ROWNUM id

1               1

2               2

3               3

4               4

5               5


SELECT ROWNUM,id

FROM
 test
CONNECT BY ROWNUM <= 2;

ROWNUM id

1               1

2               1

3               2

4               3

5               4

6               5

 

这样比上面多出来一条,至于原来为什么是这样的结果,网上也没找到让我信服的解释

那么,就自我总结下,CONNECT BY 是迭代的语句,他会从第一条开始,然后去找ROWNUM<=2的数据就是他自己本身,此时会将自己当做第二条数据ROWNUM就是2,接下来去找表中的第二条数据,但是ROWNUM已经是3,所以第一条的迭代结束,第二条开始。。。

那么不管CONNECT BY 后面ROWNUM<=n,检索出来的数据都是n+表中数据-1,而且第一条会被检索出来n次,剩下的只会检索出来一件

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值