婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Mysql中通過生日計算年齡的多種方法

Mysql中通過生日計算年齡的多種方法

熱門標(biāo)簽:銀川電銷外呼系統(tǒng)定制 甘孜電話機器人廠家 做地圖標(biāo)注都需要什么工具 電銷機器人好品牌門薩維l 中科嘉智人工智能電銷機器人 哈爾濱crm外呼系統(tǒng)價格 西安400電話在哪里辦理 凱立德科技館地圖標(biāo)注 上海智能外呼系統(tǒng)需要多少錢

以前使用mysql不是很多,對mysql的函數(shù)也不是很熟悉,遇到這個問題第一時間百度搜索,搜索到這兩種方法,這兩種方法是排在百度第一條的博客。

方法一

SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(birthday)), '%Y')+0 AS age

方法一,作者也說出了缺陷,就是當(dāng)日期為未來日期時結(jié)果為0,而不是負(fù)數(shù);這里使用了5個函數(shù)和兩個運算符。

方法二

SELECT DATE_FORMAT(NOW(), '%Y') - DATE_FORMAT(birthday, '%Y') - (DATE_FORMAT(NOW(), '00-%m-%d')  DATE_FORMAT(birthday, '00-%m-%d')) AS age

方法二,解決了方法一為負(fù)數(shù)的問題,但看起來更復(fù)雜;這里使用了6個函數(shù)和3個運算符。

看了這篇貼子后,我就暈了,怎么會這么復(fù)雜,以前用Sql Server很簡單就可以了。我堅信一定有簡單高效的方法。很快就找到了根據(jù)以上方法改良后的方法。

改良后方法一和方法二

SELECT year( from_days( datediff( now( ), birthdate)));
SELECT YEAR(CURDATE())-YEAR(birthday)-(RIGHT(CURDATE(),5)RIGHT(birthday,5));

改良后的方法一,少了一個函數(shù)和一個運算符,當(dāng)日期為未來日期時計算結(jié)果還是為0;
改良后的方法二,還是6個函數(shù)和3個運算符,看起來簡單些;取日期的右邊五位,當(dāng)日期格式為‘2013-01-01'時取到的是‘01-01',沒有問題;當(dāng)日期格式為‘2013-1-1'縮寫格式時,取右邊的五位取出的是‘3-1-1',會導(dǎo)致出錯。

然后自己根據(jù)MYSQL的幫助文檔中的日期函數(shù)想到了第三種方法:

方法三

SELECT FLOOR(DATEDIFF(CURDATE(), @birthday)/365.2422)

取生日和當(dāng)前日期之前的天數(shù)除以一年的實際天數(shù)(365天5小時48分46秒),然后取整。這樣只用了三個函數(shù)和一個運算符就搞定了。

然后,很快在國外網(wǎng)站找到了第四種方法:

方法四

 SELECT TIMESTAMPDIFF(YEAR, @birthday, CURDATE())

這種方法只用了兩個函數(shù)就搞定了,應(yīng)該是最佳方法了。

測試了一下以上四種方法,假如當(dāng)前日期為'2017-1-13',當(dāng)生日為‘2013-1-14'時,還差一天就要過生日了,離4歲只 差一天了,結(jié)果還是3歲,感覺不是很合理;把方法三改造一下,四舍五入得到方法五:

方法五

SELECT ROUND(DATEDIFF(CURDATE(), @birthday)/365.2422)

這樣計算出的年齡離實際的周歲最接近了,但可能方法四是最符合年齡定義的了。

總結(jié)

以上所述是小編給大家介紹的Mysql中通過生日計算年齡,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • Postgresql 通過出生日期獲取年齡的操作
  • Mysql出生日期轉(zhuǎn)換為年齡并分組統(tǒng)計人數(shù)的方法示例
  • sql通過日期判斷年齡函數(shù)的示例代碼

標(biāo)簽:山南 安康 那曲 平頂山 四川 浙江 安徽 濮陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql中通過生日計算年齡的多種方法》,本文關(guān)鍵詞  Mysql,中通,過生日,計算,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mysql中通過生日計算年齡的多種方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Mysql中通過生日計算年齡的多種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 芜湖县| 会昌县| 肥城市| 曲阳县| 高陵县| 鹤峰县| 宝鸡市| 邓州市| 吐鲁番市| 义乌市| 姜堰市| 武山县| 文昌市| 浦江县| 宾阳县| 双桥区| 康保县| 克山县| 柘城县| 安国市| 昌吉市| 广河县| 花垣县| 柳河县| 缙云县| 晴隆县| 社旗县| 体育| 荣昌县| 广灵县| 曲水县| 鹿泉市| 双峰县| 会理县| 方城县| 交口县| 婺源县| 平泉县| 措美县| 富平县| 尉氏县|