> 데이터 베이스 > MySQL 튜토리얼 > SQL의 getDate()를 사용하여 생년월일로부터 나이를 계산하는 방법은 무엇입니까?

SQL의 getDate()를 사용하여 생년월일로부터 나이를 계산하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2025-01-22 13:47:12
원래의
513명이 탐색했습니다.

How to Calculate Age from Date of Birth Using SQL's getDate()?

SQL의 getDate() 함수를 사용하여 생년월일을 기준으로 나이를 계산합니다

질문:

많은 데이터베이스가 생년월일을 포함한 개인 정보를 유지하고 있습니다. 기록관리를 위한 정확한 연령추적을 위해서는 저장된 생년월일을 개인의 나이(년)로 환산해야 합니다.

해결책:

문자열 날짜를 날짜 데이터 유형으로 변환:

  1. CONVERT() 함수를 사용하여 varchar 유형의 생년월일을 datetime 데이터 유형으로 변환합니다.
CONVERT(datetime, DOB)
로그인 후 복사

나이를 연 단위로 계산:

  1. DATEDIFF() 함수를 사용하여 현재 날짜 및 시간(getDate()을 사용하여 얻음)과 변환된 생년월일 간의 시간 차이를 계산합니다.
DATEDIFF(hour, CONVERT(datetime, DOB), getDate())
로그인 후 복사
  1. 시간 차이를 8766(1년의 시간 수)으로 나누어 십진수로 나이를 구합니다.
DATEDIFF(hour, CONVERT(datetime, DOB), getDate()) / 8766.0
로그인 후 복사

출력:

SELECT ID, Name, DATEDIFF(hour, CONVERT(datetime, DOB), getDate()) / 8766.0 AS AGE, DOB
FROM [YourTable];
로그인 후 복사

정확성 고려 사항:

윤년과 정확한 날짜 계산은 정확성에 영향을 미칩니다. 정확성을 높이려면 다음 사항을 고려하세요.

연령을 정수로 계산하는 가장 좋은 방법:

(CONVERT(int, CONVERT(char(8), @Now, 112)) - CONVERT(char(8), @Dob, 112)) / 10000
로그인 후 복사

나이를 소수로 계산하는 가장 좋은 방법:

1.0 * DATEADD(yy, @Dob, @Now)
+ CASE
    WHEN @Now >= DATEFROMPARTS(YEAR(@Now), MONTH(@Dob), DAY(@Dob)) THEN   -- 当年生日已过
        (1.0
        * DATEDIFF(day, DATEFROMPARTS(YEAR(@Now), MONTH(@Dob), DAY(@Dob)), @Now)
        / DATEDIFF(day, DATEFROMPARTS(YEAR(@Now), 1, 1), DATEFROMPARTS(YEAR(@Now) + 1, 1, 1))
        )
    ELSE    -- 当年生日未过
        -1 * (
            -1.0
            * DATEDIFF(day, DATEFROMPARTS(YEAR(@Now), MONTH(@Dob), DAY(@Dob)), @Now)
            / DATEDIFF(day, DATEFROMPARTS(YEAR(@Now), 1, 1), DATEFROMPARTS(YEAR(@Now) + 1, 1, 1))
        )
END
로그인 후 복사

위 내용은 SQL의 getDate()를 사용하여 생년월일로부터 나이를 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿