MySQL當中的閏月最後一天的計算問題

來源:互聯網
上載者:User

標籤:

在日期的計算當中會出現一個奇怪的問題:

如果當前日期是閏年的2月29日,那麼對當前的日期+ N 年,那麼相應的日期變為2月28日。但是這不符合我們的常識,按照常識,當只有28天的時候,時間應該順延一天,變為3月1日。

例如下面的SQL帶麼用來計算,今年的生日日期:

select name,birthday,NOW(),DATE_ADD(birthday1, INTERVAL IF(DAY(birthday)=29 && DAY(birthday1)=28,1,0) DAY) as birthday2from(    select name,birthday,DATE_ADD(birthday,INTERVAL diff YEAR) as birthday1    from(        select name,birthday,(YEAR(NOW())-YEAR(birthday)) as diff        from user    ))

其中第一層迴圈,是要計算當前日期和出生日期相差的年份。

第二層迴圈,初步計算幾年的生日日期。

第三層迴圈,進一步修正出生日期。

 

MySQL當中的閏月最後一天的計算問題

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.