ホームページ >データベース >mysql チュートリアル >SQL を使用して生年月日から年齢を正確に計算するにはどうすればよいですか?

SQL を使用して生年月日から年齢を正確に計算するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2025-01-22 13:32:41335ブラウズ

How Can I Accurately Calculate Age in Years from a Date of Birth Using SQL?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。