1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > oracle plsql递归查询语句 oracle with 语句实现递归查询

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

时间:2018-11-27 03:47:09

相关推荐

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

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

connect by用法

使用rownum实现1到10的序列。selectrownumfromdualconnectbyrownum<=10;

使用level实现1到10的序列。selectlevelfromdualconnectbylevel<=10;

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

(select1fromdual

unionall

selectn+1fromc

wheren<10)

selectnfromc;

查询当前时间往前的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可以实现同样的效果

d 表示一星期中的第几天

iw 表示一年中的第几周

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

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

fromdual

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。