SQL 日期函数如何判断闰年?

答案是通过条件表达式或日期验证判断闰年。使用模运算结合CASE判断年份是否满足“被4整除且不被100整除,或被400整除”;或尝试构造2月29日看是否为有效日期,如SQL Server用ISDATE,MySQL用STR_TO_DATE,也可封装为函数以复用。

SQL 中没有直接判断闰年的内置函数,但可以通过日期逻辑和条件表达式来实现。核心思路是根据闰年的定义:能被 4 整除且不能被 100 整除,或者能被 400 整除的年份为闰年。

使用 YEAR、CASE 和模运算判断闰年

在大多数 SQL 数据库(如 SQL Server、MySQL、PostgreSQL)中,可以提取年份并结合 CASE 表达式进行判断:

SELECT 
    year_value,
    CASE 
        WHEN (year_value % 4 = 0 AND year_value % 100 <> 0) OR (year_value % 400 = 0)
        THEN '闰年'
        ELSE '平年'
    END AS is_leap_year
FROM (
    SELECT EXTRACT(YEAR FROM CURRENT_DATE) AS year_value  -- 示例取当前年
) t;

通过检查 2 月是否有 29 天判断

另一种方法是尝试构造该年 2 月 29 日是否为有效日期。如果数据库支持日期转换,可利用此特性:

SELECT 
    2025 AS year_test,
    CASE 
        WHEN ISDATE('2025-02-29') = 1 THEN '闰年'  -- SQL Server 写法
        ELSE '平年'
    END AS is_leap_year;

注意:ISDATE() 是 SQL Server 特有函数。在 MySQL 可用 STR_TO_DATE 配合判断:

SELECT 
    CASE 
        WHEN STR_TO_DATE('2025-02-29', '%Y-%m-%d') IS NOT NULL 
        THEN '闰年'
        ELSE '平年'
    END AS is_leap_year;

封装成通用查询或函数

若频繁使用,可创建用户定义函数(以 SQL Server 为例):

CREATE FUNCTION dbo.IsLeapYear (@Year INT)
RETURNS VARCHAR(4)
AS
BEGIN
    RETURN (
        CASE 
            WHEN (@Year % 4 = 0 AND @Year % 100 <> 0) OR (@Year % 400 = 0)
            THEN '闰年'
            ELSE '平年'
        END
    );
END;

调用方式:SELECT dbo.IsLeapYear(2025);

基本上就这些方法,选择取决于你使用的数据库系统和具体场景。数学判断更通用,日期验证更直观。