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 중국어 웹사이트의 기타 관련 기사를 참조하세요!