ホームページ >データベース >mysql チュートリアル >SQL を使用して生年月日から年齢を正確に計算するにはどうすればよいですか?
生年月日に基づいて SQL で正確な年齢を計算するには、生年月日列が有効な datetime
または date
データ型である必要があります。 誕生日列が現在 nvarchar(25)
である場合は、まずそれを適切な日付形式に変換する必要があります。
この変換が完了したと仮定して、有効な年齢の計算方法を調べてみましょう:
方法 1: 簡略化されたアプローチ (近似)
このメソッドは、DATEDIFF
を使用して現在の日付と生年月日の差を時間単位で求め、それを年間のおおよその時間数 (8766.0) で割ります。
<code class="language-sql">SELECT DATEDIFF(hour, @dob, GETDATE())/8766.0 AS AgeYearsDecimal</code>
これにより、10 進数の年齢が得られますが、月ごとの日数と閏年が異なるため、その精度は制限されます。
改善され、より正確な方法:
整数年齢計算:
このメソッドは年齢を整数で計算します:
<code class="language-sql">SELECT (CONVERT(int,CONVERT(char(8),@Now,112))-CONVERT(char(8),@Dob,112))/10000 AS AgeIntYears</code>
正確な 10 進数の年齢計算:
より正確な 10 進数の年齢を求めるには、次の改良された方法をお勧めします。
<code class="language-sql">SELECT 1.0* DateDiff(yy,@Dob,@Now) +CASE WHEN @Now >= DATEFROMPARTS(DATEPART(yyyy,@Now),DATEPART(m,@Dob),DATEPART(d,@Dob)) THEN ( 1.0 * DATEDIFF(day,DATEFROMPARTS(DATEPART(yyyy,@Now),DATEPART(m,@Dob),DATEPART(d,@Dob)),@Now) / DATEDIFF(day,DATEFROMPARTS(DATEPART(yyyy,@Now),1,1),DATEFROMPARTS(DATEPART(yyyy,@Now)+1,1,1)) ) ELSE -1 * ( * DATEDIFF(day,DATEFROMPARTS(DATEPART(yyyy,@Now),DATEPART(m,@Dob),DATEPART(d,@Dob)),@Now) / DATEDIFF(day,DATEFROMPARTS(DATEPART(yyyy,@Now),1,1),DATEFROMPARTS(DATEPART(yyyy,@Now)+1,1,1)) ) END AS AgeYearsDecimal</code>
この高度な方法は閏年を考慮し、年齢を高精度に 10 進数で表します。 これは、正確な年齢の計算が必要な場合に推奨される方法です。
以上がSQL を使用して生年月日から年齢を正確に計算するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。