网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

oraclewith语句实现递归查询

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

主要从事网页设计、PC网站建设(电脑版网站建设)、wap网站建设(手机版网站建设)、响应式网站开发、程序开发、微网站、微信小程序开发等,凭借多年来在互联网的打拼,我们在互联网网站建设行业积累了丰富的成都做网站、成都网站设计、成都外贸网站建设、网络营销经验,集策划、开发、设计、营销、管理等多方位专业化运作于一体,具备承接不同规模与类型的建设项目的能力。

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', '[^|]+');

当前标题:oraclewith语句实现递归查询
URL地址:http://bjjierui.cn/article/piopgd.html

其他资讯