SQL 日期 日月递归

--日
WITH
    DATATEMP
    (
        DATELIST
    ) AS
    (
        VALUES
        (
            DATE('2022-01-01')
        )
    UNION ALL
    SELECT
        DATELIST + 1 DAY
    FROM
        DATATEMP
    WHERE
        DATELIST + 1 DAY <= DATE('2030-12-31')
    )SELECT * FROM DATATEMP
--月
WITH
    DATATEMP0
    (
        COL1,
        COL2
    ) AS
    (
        VALUES
        (
            TO_DATE('2022-01', 'YYYY-MM'),
            TO_DATE('2022-01', 'YYYY-MM') + 1 MONTHS
        )
    UNION ALL
    SELECT
        COL1 + 1 MONTHS,
        COL2 + 1 MONTHS
    FROM
        DATATEMP0
    WHERE
        COL1 + 1 MONTHS <= ADD_MONTHS(TO_DATE('2030-12', 'YYYY-MM'), 0)
    )
    ,
    DATATEMP AS
    (
        SELECT
            YEAR(COL1) * 100 + MONTH(COL1) AS MONTHS
        FROM
            DATATEMP0
    )SELECT * FROM DATATEMP 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值