从数据库中检索重叠标记半径内的结果
目标是检索落在多个标记重叠半径内的数据点地理空间数据库。为此,您必须使用圆的方程来确定某个点是否位于给定半径内。
将用户 B 的位置视为圆的中心,将用户 A 的位置视为圆周边上的点,则方程为了保持一致性,转换为公里,转换为:
((x-x1)*111.12)^2 + ((y-y1)*111.12)^2 = 4 (=2^2)
其中:
将此等式转换为 SQL 得到:
SELECT A.user_id, A.radius_id, A.latitude, A.logitude FROM UserA AS A, (SELECT user_id, latitude, longitude FROM UserB WHERE user_id = 8) AS B WHERE (POW((A.latitude-B.latitude)*111.12, 2) + POW((A.longitude - B.longitude)*111.12, 2)) <= 4
注意:为了提高准确性,请考虑使用 (A.longitude - B.longitude)*111.12*cos(A.latitude) 或 (A.longitude - B.longitude)*111.12*cos( B.latitude) 而不是等式中的 (A.longitude - B.longitude)*111.12。
以上是如何从地理空间数据库中检索重叠标记半径内的数据点?的详细内容。更多信息请关注PHP中文网其他相关文章!