"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como calcular a diferença de idade em anos como um número inteiro no MySQL?

Como calcular a diferença de idade em anos como um número inteiro no MySQL?

Publicado em 23/12/2024
Navegar:163

 How to Calculate Age Difference in Years as an Integer in MySQL?

Calculando a diferença de idade em anos como um número inteiro no MySQL

Determinar a idade de uma pessoa em um banco de dados apresenta um pequeno desafio ao lidar com cálculos de idade . Considere a tabela 'aluno' com colunas 'id' e 'data_nascimento'.

Para calcular a idade em dias, a expressão datediff(curdate(),birth_date) pode ser usada, mas retorna um valor de ponto flutuante . Dividir por 365 também produz um valor de ponto flutuante.

Calcular anos como year(curdate())-year(birth_date) também apresenta um problema. Por exemplo, se uma pessoa nasceu em junho de 1970 e a data atual for maio, a expressão retornaria incorretamente 32 anos em vez de 31.

Solução alternativa para diferença de ano inteiro:

Para resolver esse problema, considere a seguinte instrução SQL:

SELECT TIMESTAMPDIFF(YEAR, date_of_birth, CURDATE()) AS difference FROM student

Esta expressão calcula a diferença entre 'data_de_nascimento' e 'CURDATE()' em anos, resultando em um valor inteiro.

Extensão para Meses e Dias:

Para calcular a diferença em meses, substitua 'YEAR' por 'MONTH' no expressão:

SELECT TIMESTAMPDIFF(MONTH, date_of_birth, CURDATE()) AS difference FROM student

Da mesma forma, para a diferença em dias, substitua 'YEAR' por 'DAY':

SELECT TIMESTAMPDIFF(DAY, date_of_birth, CURDATE()) AS difference FROM student
Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3