Можете да изчислите разстояние, като използвате сферичен закон за косинуси :
SELECT DEGREES(ACOS(SIN(RADIANS(clients.latitude)) * SIN(RADIANS(schools.latitude)) +
COS(RADIANS(clients.latitude)) * COS(RADIANS(schools.latitude))
* COS(RADIANS(clients.longitude
– schools.longitude))))
* 60 * 1.1515 * 1.609344 AS distance
FROM clients, schools HAVING distance < $radius
RADIANS(X)
- градуси в радиани
ACOS(X )
- косинус на дъгата на X, тоест стойността, чийто косинус е X
DEGREES(X)
- радиани в градуси
60 - минути в градус
1,1515 - мили в морска миля
1,609344 - километра в миля