sql >> Database >  >> RDS >> Mysql

MySQL converteert graden, minuten, seconden naar decimaal graden

Leuke lifehack:probleemoplossing omkeren (graden naar DMS) met behulp van SEC_TO_TIME ingebouwde MySQL-functie:

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 onverwachte resultaten:IN-clausule (getal, 'string') op een varchar-kolom

  2. SQL TUSSEN-Slimme tips om te scannen op een reeks waarden

  3. MYSQL selecteer join multiple table en SUM

  4. Hoe MySQL-transacties testen?