按地理位置订购Solr /太阳黑子搜索结果

时间:2011-05-03 15:24:23

标签: ruby-on-rails ruby solr ruby-on-rails-plugins sunspot

我希望能够按分数和位置订购我的搜索结果。数据库中的每个用户都有lat / lot,我正在编制索引:

location :coordinates do
  Sunspot::Util::Coordinates.new latlon[0], latlon[1]      
end

我将执行搜索的模型也以相同的方式编入索引。基本上我想要实现的是结果按分数排序,然后按位置排序。因此,如果我搜索沃尔玛,我希望看到所有沃尔玛的地理位置靠近我的位置。

我记得读过一些关于solr的新地理排序但不确定它是否超出alpha和/或sunspot是否实现了包装器。

你会推荐什么?

1 个答案:

答案 0 :(得分:6)

由于太阳黑子计算位置类型的方式,您需要做一些额外的腿部工作,以便按目标距离进行排序。它的工作方式是为每个点创建一个地理哈希,然后使用常规全文搜索对该地理哈希进行搜索。结果是你可能无法确定10公里以外的点是否比5公里以外的点更远,但是你可以判断50公里以外的点是否比1-2公里以外的点还要远。 。确切的距离是任意的,但结果是你可能没有像你想要的那样精细的结果,而搜索更像是一种过滤在可接受的接近范围内的点的方法。使用内置位置搜索过滤点后,有三种方法可以实现您的目标:

  1. 升级到Solr 3.1或更高版本以及upgrade your schema.xml to use the new spatial search columns。然后,您需要对Sunspot进行自定义修改,以创建适用于这些新数据类型的字段和排序。据我所知,这些在太阳黑子中尚未提供,所以你必须自己建立这些连接,你必须在Solr中挖掘一些手动配置。
  2. 利用Spatial Solr Plugin。你必须在你的Solr目录中安装一个新的JAR,你必须对Sunspot进行一些修改,但它们相对轻松,可以找到完整的说明here
  3. 利用您的数据库,如果您的数据库也在位置列上编入索引,那么您可以使用太阳黑子内置位置搜索将结果过滤到合理大小的集合。然后,您可以在数据库中查询这些结果,并使用您自己的距离函数靠近您的位置进行排序。