点餐系统(五)——获取附近餐馆

  在系统中,搜索附近餐馆的时候。要依据当前的经纬度去获取附近指定距离的餐馆信息。在这个需求中就必需要依据经纬度去计算餐馆和当前经纬度的距离。

之前的做法是由于用sybase数据库。所以计算距离都是获取完数据之后进行两点之间的计算。可是眼下已经弃用sybase数据库,所以我想着在sql里面之间作为条件去查询符合条件的餐馆。


  在sql中的语句例如以下
    
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距离的餐馆

    

posted @ 2016-01-13 19:20  zfyouxi  阅读(270)  评论(0编辑  收藏  举报