Table used
data:image/s3,"s3://crabby-images/87983/87983aec45f6328876c573d19c3e95ecdbe2125e" alt="inserir a descrição da imagem aqui"
Consultation held day 31/08 at 21:29hs from the server
SELECT
CONCAT(
TIMESTAMPDIFF(day,NOME_COLUNA,now()) , ' dias ',
MOD( TIMESTAMPDIFF(hour,NOME_COLUNA,now()), 24), ' hs ',
MOD( TIMESTAMPDIFF(minute,NOME_COLUNA,now()), 60), ' min '
) from NOME_TABELA
Upshot
data:image/s3,"s3://crabby-images/e32ba/e32bada12a0abfaae2d99675b4d305333905546a" alt="inserir a descrição da imagem aqui"
- CONCAT function to join query values
- TIMESTAMPDIFF - function to calculate the difference between dates
Order of consultation
For alphanumeric fields 10 comes before a 2 because the evaluation is done from left to right type by digit.
Table used:
data:image/s3,"s3://crabby-images/ca257/ca2576c8cee818c94bfec4a6dbb9fa4ab54e356d" alt="inserir a descrição da imagem aqui"
Upshot:
data:image/s3,"s3://crabby-images/3b8e8/3b8e8b6685fef4399d1bb1e246eff292eaba0e3f" alt="reult asc"
With numeric values the default order is from the lowest to the highest, unless specified DESC
in order by
To order the result, since it is always started by a number, you can convert the result of the query into a number that the sql will capture the part before the letters and convert to a number, then sort the result by this value.
Consultation:
SELECT
CONCAT(
TIMESTAMPDIFF(day,NOME_COLUNA,now()) , ' dias ',
MOD( TIMESTAMPDIFF(hour,NOME_COLUNA,now()), 24), ' hs ',
MOD( TIMESTAMPDIFF(minute,NOME_COLUNA,now()), 60), ' min '
) as resultado from NOME_TABELA ORDER BY CAST(resultado AS UNSIGNED INTEGER)
data:image/s3,"s3://crabby-images/827eb/827eb830e12fdf14de8c167670222eac20c20ad5" alt="ordenada"
You already have an answer on the subject: https://answall.com/questions/57/howto calculate a difference%C3%A7a-between-two-dates/70
– novic
The @Bacco response seems like a good suggestion that goes beyond mysql: How to humanize a date in PHP
– Guilherme Nascimento