用于选择指定范围内坐标的MySQL查询
在您的数据库中,您有大量的地址,每个地址都有自己的纬度和经度。您希望使用 Google Maps API 在地图上仅显示指定用户位置 5 英里半径范围内的地址。
为了避免不必要地检索所有记录并在 Java 中执行距离计算,这将是低效的,考虑在 MySQL 查询中使用半正矢公式。该公式将计算地球表面上两点之间的距离。以下是修改后的查询:
<code class="sql">SELECT *, (3959 * acos(cos(radians(?)) * cos(radians(lat)) * cos(radians(lng) - radians(?)) + sin(radians(?)) * sin(radians(lat)))) AS distance FROM your_table HAVING distance < 5</code>
在此查询中,将问号 (?) 替换为用户位置的纬度和经度值(Java 代码中的 $lat 和 $lng)。距离列将存储每个地址与用户位置之间的距离。
通过使用此查询,您将只检索指定范围内的地址,优化您的查询性能。
以上是如何在MySQL中使用半正矢公式高效查询特定范围内的地址?的详细内容。更多信息请关注PHP中文网其他相关文章!