Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Converter segundos para duração de tempo legível por humanos

TIME_FORMAT(SEC_TO_TIME(task_records.time_spent),'%Hh %im')

A documentação é sua amiga:

De acordo com o comentário:
DROP FUNCTION IF EXISTS GET_HOUR_MINUTES;
CREATE FUNCTION GET_HOUR_MINUTES(seconds INT)
  RETURNS VARCHAR(16)

  BEGIN
  DECLARE result VARCHAR(16);
  IF seconds >= 3600 THEN SET result = TIME_FORMAT(SEC_TO_TIME(seconds),'%kh %lm');
  ELSE SET result = TIME_FORMAT(SEC_TO_TIME(seconds),'%lm');
  RETURN result;
  END

DELIMETER ;

Uso:
SELECT GET_HOUR_MINUTES(task_records.time_spent) FROM table