sql >> Base de Datos >  >> RDS >> Mysql

Convertir segundos a duración de tiempo legible por humanos

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

La documentación es tu amiga:

Según el comentario:

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