在系统中,搜索附近餐馆的时候。要依据当前的经纬度去获取附近指定距离的餐馆信息。在这个需求中就必需要依据经纬度去计算餐馆和当前经纬度的距离。
之前的做法是由于用sybase数据库。所以计算距离都是获取完数据之后进行两点之间的计算。可是眼下已经弃用sybase数据库,所以我想着在sql里面之间作为条件去查询符合条件的餐馆。
在sql中的语句例如以下
查询出来的数据就是小于5km距离的餐馆
select * from mer where sqrt( ( ((113.60189578775-mer_gps_longitude)*PI()*12656*cos(((24.80864699442+mer_gps_latitude)/2)*PI()/180)/180) * ((113.60189578775-mer_gps_longitude)*PI()*12656*cos (((24.80864699442+mer_gps_latitude)/2)*PI()/180)/180) ) + ( ((24.80864699442-mer_gps_latitude)*PI()*12656/180) * ((24.80864699442-mer_gps_latitude)*PI()*12656/180) ) )<5
查询出来的数据就是小于5km距离的餐馆