sql >> Database teknologi >  >> RDS >> Mysql

MySQL konverterer grader, minutter, sekunder til grader decimaler

Nice lifehack:omvendt problemløsning (grad til DMS) ved hjælp af SEC_TO_TIME indbygget MySQL-funktion:

CREATE FUNCTION `geocoords`(lon double, lat double) RETURNS varchar(24) CHARSET cp1251
    NO SQL
    DETERMINISTIC
begin    
  declare alon double;
  declare alat double;
  declare slon varchar(12);
  declare slat varchar(12);
  set alon = abs(lon);
  set alat = abs(lat);
  set slon = TIME_FORMAT(SEC_TO_TIME(alon*3600), '%H°%i''%s"');
  set slat = TIME_FORMAT(SEC_TO_TIME(alat*3600), '%H°%i''%s"');
  if lon>0 then
    set slon = concat(slon, 'E');
  elseif lon<0 then  
    set slon = concat(slon, 'W');
  end if;  
  if lat>0 then
    set slat = concat(slat, 'N');
  elseif lat<0 then  
    set slat = concat(slat, 'S');
  end if;  
  return concat(slat, ' ', slon);
end


  1. MySQL loop gennem tabeller

  2. Find det mindste ubrugte tal i SQL Server

  3. Forespørgsel for at få den laveste værdi, der er større end nul, og er ikke NULL

  4. Parse parameterstandardværdier ved hjælp af PowerShell – Del 3