SQL年齡計算的兩種方法實例
第一種方法:
用DATEDIFF函數,DATEDIFF(YEAR,beginDate,endDate)
。
測試語句:
DECLARE @birthdayDate DATE DECLARE @endDate DATE DECLARE @age INT SET @birthdayDate ='2003-08-08' SET @endDate = '2008-07-08' SET @age = DATEDIFF(YEAR,@birthdayDate,@endDate) SELECT @age AS 年齡
執行結果:
這種方法計算出的年齡,是個大概年齡,是“年”意義下的年齡,就是普羅大眾對年齡的理解下的年齡。
如果按“月”、“日”去計算,上述例子中的年齡其實是不足5歲的。
所以,當我們寫的程序對年齡的計算的精度要求比較高時,
比如社保待遇的享受起始時間、退休金發放起始時間的計算,需要對年齡的精確計算;
政治生活中,幹部的提拔、退職,也都涉及到年齡的精確計算;
民事刑事案件中當事人年齡的計算,年齡的大小直接涉及到量刑的輕重,所以也需要對年齡進行精確計算。
第二種方法:
FLOOR(DATEDIFF(DAY,@birthdayDate,@endDate)/365.25)
FLOOR函數:返回小於或等於指定數值表達式的最大整數。又稱,向下取整函數。
(Returns the largest integer less than or equal to the specified numeric expression.)
PS:numberic expression,數值表達式 ,arithmeric expression,算術表達式。
FLOOR(4)=4,
FLOOR(4.2)=4,
FLOOR(4.5)=4,
FLOOR(4.9)=4.
測試語句:
DECLARE @birthdayDate DATE DECLARE @endDate DATE DECLARE @age FLOAT SET @birthdayDate ='2003-08-08' SET @endDate = '2008-07-08' SET @age = FLOOR(DATEDIFF(DAY,@birthdayDate,@endDate)/365.25) SELECT @age AS 年齡
執行結果:
算法釋義:
因為4年有一閏年會多1天,多除以0.25,相當於把這一天平均攤到這4年,保證每4年的誤差歸零。
這個算法其實也有小小的誤差,除非出生不滿一歲就碰到閏月,先有一天再來遞減,會完全正確,不然的話在遇到閏年前會差一天,遇到閏年後變準確,但是當這個閏年補完4年差額在遇到下一個閏年之前又會差一天。也就是生日當天程序會顯示沒滿周歲。
我們測試一下,比如2000、2004、2008年是閏年,但是2001、2002、2003、2005、2006、2007年都不是閏年。
假定李某在2001-02-08出生,我們用2002、2003、2004年生日當天去計算年齡時,都會發生誤差。
因為2004年是閏年,用2005年生日當天去計算年齡就正確,過瞭2005年(2005-2001=4),我們用2006、2007、2008年生日當天去計算年齡,也會發生誤差。
如果李某在2001-03-08(隻要過瞭2月的一個日期就行)出生,
我們用2002、2003年生日當天去計算年齡時,會發生誤差。
但是用2004、2005年生日當天去計算年齡就正確,過瞭2005年(2005-2001=4),我們用2006、2007年生日當天去計算年齡,也會發生誤差。
用2008年生日當天去計算年齡,就沒有誤差。
請讀者自行驗證。
總結
到此這篇關於SQL年齡計算的文章就介紹到這瞭,更多相關SQL年齡計算內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- SQL Server中數學函數的用法
- sql語句中日期相減的操作實例代碼
- SQL Server中日期時間函數的用法詳解
- 關於SqlServer中datediff用法
- MySQL DATEDIFF函數獲取兩個日期的時間間隔的方法