oraclewith语句实现递归查询-创新互联

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

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、成都网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的岗巴网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

connect by用法

使用rownum实现1到10的序列。

select rownum from dual connect by rownum<=10;

oracle with 语句实现递归查询

使用level实现1到10的序列。

select level from dual connect by level<=10;

oracle with 语句实现递归查询

with 可实现同样功能用法:

with c(n) as (select 1 from dual union all select n+1 from c where n<10) select n from c;

oracle with 语句实现递归查询

更多connect by 用法参考:https://blog.csdn.net/wang_yunj/article/details/51040029/

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

oracle with 语句实现递归查询

  • d 表示一星期中的第几天

  • iw 表示一年中的第几周

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

  1. 比如说分割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', '[^|]+');

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前标题:oraclewith语句实现递归查询-创新互联
文章地址:http://bzwzjz.com/article/csgpdc.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都定制网站建设 定制网站制作 成都网站制作 成都网站设计公司 营销网站建设 网站设计 H5网站制作 成都网站设计 古蔺网站建设 成都响应式网站建设 成都网站建设 营销型网站建设 高端网站设计推广 重庆网站设计 成都企业网站建设 外贸网站建设 成都网站制作 成都商城网站制作 成都做网站建设公司 重庆手机网站建设 成都网站设计 企业网站设计