Ho appena iniziato a utilizzare MySQL con PHP e mi piacerebbe sapere se è possibile creare una funzione personalizzata. Questo snippet di codice dovrebbe illustrare ciò che sto cercando di fare.Creazione di una funzione MySQL personalizzata?
// 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);
Grazie in anticipo per qualsiasi aiuto!
Proprio A proposito, si può fare perfettamente trovano da una query. Infatti, se si utilizza un indice spaziale basato sul proprio lat/lngs e si scoprirà che i risultati sono impressionanti. Incredibile infatti. – Layke
Non sono sicuro di cosa intendi, potresti approfondire? Anche per "inadatto" non intendevo in termini di prestazioni (non ne so nulla); Intendevo con quanta pazienza sarebbe stata la domanda. –