如何实现按照距离排序? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hackingwu
V2EX    编程

如何实现按照距离排序?

  •  
  •   hackingwu 2015-08-12 22:30:01 +08:00 4140 次点击
    这是一个创建于 3788 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我现在要做一个按照距离排序的,数据库是MySQL,如果我每次请求列表都从数据库中计算两个点的距离(经纬度)计算,一定相关慢?请教一下一般大家都是如何实现?
    我的想法是对备份数据到redis中,每一次请求来,以请求的经纬度做key,去之前备份的redis数据中做一次排序,然后再缓存到redis中,以后的请求如果和其中的key做比较,如果相聚1km则使用缓存的。

    7 条回复    2015-08-13 00:11:34 +08:00
    wy315700
        1
    wy315700  
       2015-08-12 22:30:49 +08:00
    geohash
    Andiry
        2
    Andiry  
       2015-08-12 22:42:32 +08:00 via Android
    把地图划分成方块,然后按方块距离排序,有精确要求的话方块内部再排序
    publicID001
        3
    publicID001  
       2015-08-12 23:00:52 +08:00
    PgSQL大法豪
    ljbha007
        4
    ljbha007  
       2015-08-12 23:28:47 +08:00
    缓存并没有叼用 除非目标点坐标重复的很多 而且是一点都不能偏
    我看了下MySQL的Spatial Index也只是用来查找确切值 不能用来计算距离
    最好的办法也只有先限定范围 然后再排序 排序的时候算平方和就可以了 不用开根号
    ljbha007
        5
    ljbha007  
       2015-08-12 23:39:04 +08:00
    据我了解MongoDB的2dsphere index可以用来给距离排序优化 具体原理手册里没说
    还有个优点是 MongoDB计算的是球面距离 MySQL计算的是平面距离
    如果修改成本不大可以迁移到MongoDB
    现在基本可以当作MySQL用了
    或者仅把坐标数据放mongoDB 然后跨数据库用ID来关联
    相当于是用mongoDB给MySQL做索引
    ETiV
        7
    ETiV  
       2015-08-13 00:11:34 +08:00 via iPhone
    给 geohash 投一票

    经纬度> geohash字符串

    将GH串、经纬度一起存进数据库,并给字符串加以索引。

    查询的时候用 like wxx% 前缀索引,query 执行起来很快的。这步query是筛选,计算距离跟排序可以放到程序里算。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2773 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 28ms UTC 14:56 PVG 22:56 LAX 06:56 JFK 09:56
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86