oracle递归with子句

比如现在想获取开始日期到结束日期每个月的月底日期,这个时候可以通过递归实现:

sql 复制代码
--通过递归with子句获取开始日期到结束日期每个月的月末日期
WITH date_range (month_start, month_end) AS (
  SELECT TRUNC(to_date('@bdate','yyyy-mm-dd'), 'MM'),
         LAST_DAY(to_date('@bdate','yyyy-mm-dd'))
  FROM dual
  UNION ALL
  SELECT ADD_MONTHS(month_start, 1),
         LAST_DAY(ADD_MONTHS(month_start, 1))
  FROM date_range
  WHERE ADD_MONTHS(month_start, 1) <= to_date('@edate','yyyy-mm-dd')
)

SELECT month_end
FROM date_range

这个查询使用了递归查询 (WITH 子句) 来生成开始日期到结束日期范围内每个月的起始日期和结束日期。在递归的每一步中,我们使用 ADD_MONTHS() 函数来计算下一个月的起始日期,并使用 LAST_DAY() 函数获取当前月的月末日期。

在查询的最后一部分,我们选择了生成的月末日期,并将它们作为结果返回。

另一个例子:

当在Oracle数据库中使用递归WITH子句时,一个常见的示例是计算斐波那契数列(Fibonacci sequence)。斐波那契数列是一个无限序列,每个数字都是前两个数字之和。

下面是一个使用递归WITH子句生成斐波那契数列的示例:

WITH fib_seq(n, f1, f2) AS ( SELECT 1, 0, 1 FROM dual UNION ALL SELECT n + 1, f2, f1 + f2 FROM fib_seq WHERE n < 10 ) SELECT f1 as fibonacci_number FROM fib_seq;

在这个示例中,我们定义了一个递归WITH子句fib_seq,它包含三列:n表示当前数字的位置,f1表示前一个数字,f2表示当前数字。初始查询部分是斐波那契数列的第一个数字,即0和1。递归查询部分通过在之前的结果上计算得到下一个数字,直到达到预定的终止条件(在这里是n<10)。

最后,我们从递归结果中选择列f1作为斐波那契数列的每个数字,并将其作为结果返回。

执行这个查询将生成斐波那契数列的前十个数字:0、1、1、2、3、5、8、13、21、34。

这是一个简单的示例来说明递归WITH子句的使用方法。你可以根据自己的需求和逻辑定义不同的递归查询。

相关推荐
雨辰AI9 分钟前
SpringBoot3 整合达梦 DM9 超详细入门实战|从零搭建可直接上线
数据库·微服务·架构·政务
我是一颗柠檬21 分钟前
【MySQL全面教学】MySQL性能优化实战Day13(2026年)
数据库·后端·sql·mysql·性能优化·database
AI人工智能+电脑小能手39 分钟前
【大白话说Java面试题 第84题】【Mysql篇】第14题:为什么用 InnoDB 存储引擎的表建议用整型的自增主键?
java·开发语言·数据库·mysql·面试
张彦峰ZYF1 小时前
检索增强生成(RAG)系统的基础:全面深入矢量数据库
数据库·大模型·rag
Elastic 中国社区官方博客2 小时前
我们如何在 Elasticsearch Serverless 上将向量搜索吞吐量提升一倍
大数据·数据库·人工智能·elasticsearch·搜索引擎·云原生·serverless
一 乐2 小时前
高校实习信息发布网站|基于Spring Boot的高校实习信息发布网站的设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·高校实习信息发布网站
weelinking2 小时前
【产品】11_实现后端接口——数据在背后如何流动
java·人工智能·python·sql·oracle·json·ai编程
zgl_200537792 小时前
源代码:跨数据库通用SQL语法解析与标注拆解
大数据·数据库·数据仓库·sql·etl·源代码管理
雪度娃娃3 小时前
存储器层次结构——磁盘硬盘存储
服务器·网络·数据库·计算机组成原理
暴力求解3 小时前
Mysql数据库基础
数据库·mysql·操作系统