MySQL에서 정확한 연령 차이를 연 단위로 계산하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-10-31 12:12:01
원래의
967명이 탐색했습니다.

How to Calculate the Accurate Age Difference in Years in MySQL?

MySQL의 연도별 연령 차이 계산: 종합 솔루션

데이터베이스에 저장된 개인의 연령을 확인하는 것은 일반적인 작업입니다. 그러나 기존 방법을 사용하면 부정확하거나 바람직하지 않은 데이터 형식이 발생하는 경우가 많기 때문에 두 날짜 사이의 연도 차이를 계산하는 것이 어려울 수 있습니다.

"id" 및 "birth_date" 열이 있는 "student"라는 이름의 단순화된 테이블이 있다고 가정해 보겠습니다. ." 목표는 각 학생의 나이를 연 단위로 계산하는 것입니다.

초기 시도 및 과제

다음 쿼리를 사용합니다.

select id, datediff(curdate(),birth_date) 
from student
로그인 후 복사

우리는 원하는 결과가 아닌 일수로 연령 차이를 얻습니다. 365로 나누기:

select id, datediff(curdate(),birth_date) / 365
from student
로그인 후 복사

정수 대신 부동 소수점 값을 생성합니다. 마지막으로 계산:

select id, year(curdate())-year(birth_date) 
from student
로그인 후 복사

현재 날짜 이후의 생일로 인해 부정확한 결과가 발생하여 잘못된 연령 계산이 발생합니다.

대체 솔루션

이러한 문제를 해결하려면 다음 쿼리를 고려하세요.

SELECT TIMESTAMPDIFF(YEAR, date_of_birth, CURDATE()) AS difference FROM student
로그인 후 복사

TIMESTAMPDIFF() 함수를 사용하면 생일이 현재 연도에 속하더라도 연도를 정확하게 계산할 수 있습니다.

유연성을 높이려면 "YEAR"를 "MONTH" 또는 "DAY"로 바꿔 각각 월 또는 일의 차이를 계산하세요.

이 솔루션은 저장된 두 날짜 사이의 연도 차이를 확인하는 정확하고 정밀한 방법을 제공합니다. MySQL 데이터베이스에서.

위 내용은 MySQL에서 정확한 연령 차이를 연 단위로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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