sql >> Databasteknik >  >> RDS >> Mysql

Konvertera sekunder till läsbar tidslängd

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

Dokumentation är din vän:

Enligt kommentar:

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 ;

Användning:

SELECT GET_HOUR_MINUTES(task_records.time_spent) FROM table


  1. Hur ändrar jag en MySQL-kolumn för att tillåta NULL?

  2. Hur man tar bort siffror från slutet av strängen med SQL

  3. Ska jag inaktivera MySQL strikt läge?

  4. MYSQL trunkerat felaktigt DOUBLE-värde