Acabo de empezar a usar MySQL con PHP y me gustaría saber si es posible crear una función personalizada. Este fragmento de código debe ilustrar lo que intento hacer.¿Cómo crear una función MySQL personalizada?
// a somewhat complicated formula not suitable to embed into the query
function Distance($latA, $lonA, $latB, $lonB)
{
// earth's radius
$radius = 3956;
$latA = deg2rad($latA);
$lonA = deg2rad($lonA);
$latB = deg2rad($latB);
$lonB = deg2rad($lonB);
// calculate deltas
$deltaLat = $latB - $latA;
$deltaLon = $lonB - $lonA;
// calculate Great Circle distance
$result = pow(sin($deltaLatitude/2.0), 2) + (cos($latA) * cos($latB) * pow(sin($deltaLon/2.0), 2));
$distance = $radius * 2 * atan2(sqrt($result), sqrt(1 - $result));
return $distance;
}
// how can I call Distance() in my query?
$query = "SELECT lat, lon FROM zipcodes WHERE Distance(lat, lon, 0, 0) < 20";
mysql_query($query);
¡Gracias de antemano por cualquier ayuda!
Para su información, puede hacer que la hallan perfectamente desde una consulta. De hecho, si usa un índice espacial basado en sus lat/lngs, verá que los resultados son impresionantes. Increíble de hecho. – Layke
No estoy seguro de lo que quieres decir, ¿podrías explicar esto? También por "inadecuado" no quise decir en términos de rendimiento (no sé nada de eso); Quise decir cuán dolorosamente larga sería la consulta. –