前言
当前大多数app都有查找附近的功能, 简单的有查找周围的运动场馆, 复杂的有滴滴, 摩拜查找周围的车辆. 本文主要阐述查找附近地点的一般实现. 搜索附近的人也是同样的思路.
方案比较
方案1 (性能还不错)
数据库直接存经纬度, 然后计算矩形边界值, 走索引查询
方案2 (还没试过)
将经纬度转换成 一个值, 然后进行比较查询 genhash
方案3 (据说高性能, 性能怎样?待测试)
方案1的实现(本文主要阐述此方案)
实现环境: java+MySQL
场景模拟: 张三用户在成都天府五街查询周围10公里内的地点
1. 首先建立经纬度数据, 比如常见地点的经纬度数据库, 我这里是网上下载的一个shop_area 表数据,里面包含了一些常见地点的经纬度 ,如下图
2. 然后根据张三用户所在的经纬度, 以及他要查询的距离10公里, 得到查询范围矩形的四个顶点, 如下图:
计算这四个点的 mybatis sql:
SELECT
#{myLongitude} - #{distance} / ABS(COS(RADIANS(#{myLatitude})) * 69) AS LongitudeMin,
#{myLongitude} + #{distance} / ABS(COS(RADIANS(#{myLatitude})) * 69) AS LongitudeMax,
#{myLatitude} - (#{distance} / 69) AS LatitudeMin,
#{myLatitude} + (#{distance} / 69) AS LatitudeMax
3. 将刚才得到的矩形四个点的值代入如下sql 来进行经纬度查询过滤, 记得经纬度字段要建立索引
mybatis sql:
SELECT *
FROM (