在 SQL 中,WEEKDAY()
函数用于返回日期对应的星期几。关于闰年的处理,WEEKDAY()
函数通常遵循 ISO 周日期系统,其中周日被视为一周的第一天(返回值为 1),周六为第七天(返回值为 7)。在 ISO 周日期系统中,闰年的2月29日属于下一年的周,而不是当前年份。
以下是一个关于如何在 SQL 中使用 WEEKDAY()
函数处理闰年的示例:
-- 创建一个包含日期的临时表 WITH dates AS ( SELECT '2020-02-28' AS date -- 闰年的2月28日 UNION ALL SELECT '2020-02-29' AS date -- 闰年的2月29日 UNION ALL SELECT '2021-02-28' AS date -- 非闰年的2月28日 ) -- 使用 WEEKDAY() 函数获取每个日期对应的星期几 SELECT date, WEEKDAY(date) AS weekday FROM dates;
输出结果:
date | weekday ------------+--------- 2020-02-28 | 6 2020-02-29 | 7 2021-02-28 | 6
在这个示例中,WEEKDAY()
函数将闰年的2月29日视为下一年的周的一部分(返回值为 7),而不是当前年份的周。