sql >> Databáze >  >> RDS >> Mysql

MySQL převádí stupně, minuty, sekundy na stupně v desítkové soustavě

Pěkný lifehack:obrácené řešení problému (na stupeň DMS) pomocí SEC_TO_TIME vestavěné funkce MySQL:

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. Jak mohu spočítat počet slov v řetězci v Oracle?

  2. SQL:výběr řádků, kde se hodnota sloupce změnila oproti předchozímu řádku

  3. Jak přesunout model mezi dvěma aplikacemi Django (Django 1.7)

  4. PHP mysql prohledává více tabulek pomocí klíčového slova