> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 생년월일로 나이를 계산하는 방법은 무엇입니까?

MySQL에서 생년월일로 나이를 계산하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-15 12:30:02
원래의
294명이 탐색했습니다.

How to Calculate Age from Date of Birth in MySQL?

MySQL에서 생년월일로부터 나이 검색

MySQL 필드에 저장된 생년월일을 기준으로 고객의 나이를 계산하려면 , 연령 계산의 개념을 고려하는 것이 필수적입니다. 나이는 현재 날짜와 생년월일의 차이로 결정되며, 생년월일이 해당 연도 내에 있으면 나이를 1씩 줄여야 합니다.

해결책:

이를 달성하려면 다음 쿼리를 사용할 수 있습니다.

SELECT DATE_FORMAT(NOW(), '%Y') - DATE_FORMAT(dob, '%Y') - 
(DATE_FORMAT(NOW(), '00-%m-%d') < DATE_FORMAT(dob, '00-%m-%d')) AS age
로그인 후 복사
로그인 후 복사

분석:

  • DATE_FORMAT(NOW( ), '%Y'): 현재 연도를 검색합니다.
  • DATE_FORMAT(dob, '%Y'): dob 필드에서 연도 구성 요소를 검색합니다.
  • DATE_FORMAT(NOW(), '00-%m-%d') < DATE_FORMAT(dob, '00-%m-%d'): 현재 연도가 이미 고객의 생일을 지났는지 확인하여 부울 값(참은 1, 거짓은 0)을 얻습니다.
  • 이를 뺍니다. 연도 차이의 부울 값은 고객의 현재 나이를 정확하게 반영하도록 나이를 조정합니다.

예:

dob 필드에 다음 값이 포함되어 있다고 가정합니다. : 1985-03-15. 현재 날짜가 2023년 4월 28일인 경우 쿼리는 다음과 같은 결과를 생성합니다.

SELECT DATE_FORMAT(NOW(), '%Y') - DATE_FORMAT(dob, '%Y') - 
(DATE_FORMAT(NOW(), '00-%m-%d') < DATE_FORMAT(dob, '00-%m-%d')) AS age
로그인 후 복사
로그인 후 복사
SELECT 2023 - 1985 - (20230428 < 19850315) AS age
로그인 후 복사
SELECT 38 - 0 AS age
로그인 후 복사
age = 38
로그인 후 복사

따라서 이 향상된 쿼리를 사용하면 다음의 나이를 검색할 수 있습니다. 보다 정확하게 MySQL 필드에 저장된 생년월일을 기준으로 고객을 확인할 수 있습니다.

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

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