oracle plsql递归查询语句,oracle with 语句实现递归查询

Oracle with 语句可以实现如同connect by 语句一样的序列:

connect by用法

使用rownum实现1到10的序列。select rownum from dual connect by rownum<=10;

c54ed4f2ef0f846f6efbd6c0ac3645f9.png

使用level实现1到10的序列。select level from dual connect by level<=10;

35a8e6e15159d9993904871f0fee3f1e.png

with 可实现同样功能用法:with c(n) as

(select 1 from dual

union all

select n+1 from c

where n<10)

select n from c;

0746986c05b203133ea1da009876259a.png

查询当前时间往前的12周的开始时间、结束时间、第多少周:

select sysdate - (to_number(to_char(sysdate - 1, 'd')) - 1) -

(rownum - 1) * 7 as startDate,

sysdate + (7 - to_number(to_char(sysdate - 1, 'd'))) -

(rownum - 1) * 7 as endDate,

to_number(to_char(sysdate, 'iw')) - rownum + 1 as weekIndex  from dualconnect by level<= 12;--将level改成rownum可以实现同样的效果

c33bfd7c94c2d8245b8483beb5a9ae77.png

d 表示一星期中的第几天

iw 表示一年中的第几周

字符串分割,由一行变为多行:

比如说分割01|02|03|04这种有规律的字符串select REGEXP_SUBSTR('01|02|03|04', '[^|]+', 1, rownum) as newport

from dual

connect by rownum <= REGEXP_COUNT('01|02|03|04', '[^|]+');

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值