在 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),而不是當前年份的周。