• oracle递归with子句


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

    1. --通过递归with子句获取开始日期到结束日期每个月的月末日期
    2. WITH date_range (month_start, month_end) AS (
    3. SELECT TRUNC(to_date('@bdate','yyyy-mm-dd'), 'MM'),
    4. LAST_DAY(to_date('@bdate','yyyy-mm-dd'))
    5. FROM dual
    6. UNION ALL
    7. SELECT ADD_MONTHS(month_start, 1),
    8. LAST_DAY(ADD_MONTHS(month_start, 1))
    9. FROM date_range
    10. WHERE ADD_MONTHS(month_start, 1) <= to_date('@edate','yyyy-mm-dd')
    11. )
    12. SELECT month_end
    13. 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子句的使用方法。你可以根据自己的需求和逻辑定义不同的递归查询。

  • 相关阅读:
    教程图文详解 - 计算机网络概论(第一章)
    虚拟机字节码执行引擎——动态类型语言支持
    redis内存淘汰策略
    《ElementPlus 与 ElementUI 差异集合》icon 图标使用(包含:el-button,el-input和el-dropdown 差异对比)
    无人机el检测仪解析
    【深度学习】DDPM,Diffusion,概率扩散去噪生成模型,原理解读
    跟我学c++中级篇——类型擦除
    git快速上手指南
    轴承寿命预测的基础-对Palmgren理论的再讨论
    Linux——centos7.4磁盘空间调整分配
  • 原文地址:https://blog.csdn.net/weixin_38314865/article/details/132834841