答案是通过条件表达式或日期验证判断闰年。使用模运算结合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
2024 AS year_test,
CASE
WHEN ISDATE('2024-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('2024-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(2024);
基本上就这些方法,选择取决于你使用的数据库系统和具体场景。数学判断更通用,日期验证更直观。










