Je moet kijken naar het gebruik van de Haversine-formule . U vindt tal van online voorbeelden die u laten zien hoe u de formule in zowel PHP als SQL kunt implementeren.
Google heeft een mooi voorbeeld voor MySQL :
SELECT id, ( 3959 * acos( cos( radians(37) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians(-122) ) + sin( radians(37) ) * sin( radians( lat ) ) ) ) AS distance
FROM markers HAVING distance < 25 ORDER BY distance LIMIT 0 , 20;