MySQL의 연령 차이를 정수로 계산
데이터베이스에서 개인의 연령을 확인하는 것은 날짜 계산을 처리할 때 어려울 수 있습니다. MySQL의 내장 함수 DATEDIFF는 두 날짜 간의 차이를 일 단위로 계산하므로 연도 단위의 나이를 얻으려면 추가 처리가 필요합니다.
한 가지 접근 방식에서는 일 수의 차이를 365로 나누는 방법이 있지만 결과적으로 부동 소수점 값. 정수를 얻으려면 현재 날짜와 생년월일의 연도 구성 요소를 뺄 수 있습니다.
SELECT id, year(curdate())-year(birth_date) FROM student
그러나 이 접근 방식은 이번 달 이후에 태어난 개인에 대해 계산된 연령이 1년 차이나는 경우 문제가 발생합니다. . 예를 들어, 1970년 6월에 태어난 사람은 이 방법을 사용하면 31세 5개월에 불과하더라도 32세로 간주됩니다.
해결 방법:
To 이 문제를 해결하기 위해 MySQL은 연령 차이를 계산하는 보다 정확한 접근 방식을 제공하는 TIMESTAMPDIFF 함수를 제공합니다. 다음 쿼리는 TIMESTAMPDIFF를 활용합니다.
SELECT TIMESTAMPDIFF(YEAR, date_of_birth, CURDATE()) AS difference FROM student
YEAR를 MONTH 또는 DAY로 바꾸면 연령 차이를 각각 월 또는 일 단위로 계산할 수 있습니다. 이 방법은 특정 월 동안 연령이 한 단위씩 벗어나는 시나리오를 효과적으로 처리합니다.
위 내용은 MySQL을 사용하여 연령 차이를 정확하게 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!