http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 4700|回复: 3

[搜索引擎] 37-Elasticsearch 地理坐标盒模型过滤器

[复制链接]
发表于 2019-1-8 08:50:08 | 显示全部楼层 |阅读模式
这是目前为止最有效的地理坐标过滤器了,因为它计算起来非常简单。

你指定一个矩形的 顶部 , 底部 , 左边界 ,和 右边界 ,然后过滤器只需判断坐标的经度是否在左右边界之间,纬度是否在上下边界之间:

[C#] 纯文本查看 复制代码
GET /attractions/restaurant/_search

{

  "query": {

    "filtered": {

      "filter": {

        "geo_bounding_box": {

          "location": { 

            "top_left": {

              "lat":  40.8,

              "lon": -74.0

            },

            "bottom_right": {

              "lat":  40.7,

              "lon": -73.0

            }

          }

        }

      }

    }

  }

}



这些坐标也可以用 bottom_left 和 top_right 来表示。

优化盒模型
地理坐标盒模型过滤器 不需要把所有坐标点都加载到内存里。 因为它要做的 只是简单判断 lat 和 lon 坐标数值是否在给定的范围内,可以用倒排索引做一个 range 过滤来实现目标。

要使用这种优化方式,需要把 geo_point 字段 用 lat 和 lon 的方式分别映射到索引中:

[C#] 纯文本查看 复制代码
PUT /attractions

{

  "mappings": {

    "restaurant": {

      "properties": {

        "name": {

          "type": "string"

        },

        "location": {

          "type":    "geo_point",

          "lat_lon": true 

        }

      }

    }

  }

}



location.lat 和 location.lon 字段将被分别索引。它们可以被用于检索,但是不会在检索结果中返回。

然后,查询时你需要告诉 Elasticesearch 使用已索引的 lat 和 lon :

[C#] 纯文本查看 复制代码
GET /attractions/restaurant/_search

{

  "query": {

    "filtered": {

      "filter": {

        "geo_bounding_box": {

          "type":    "indexed", 

          "location": {

            "top_left": {

              "lat":  40.8,

              "lon": -74.0

            },

            "bottom_right": {

              "lat":  40.7,

              "lon":  -73.0

            }

          }

        }

      }

    }

  }

}



设置 type 参数为 indexed (替代默认值 memory )来明确告诉 Elasticsearch 对这个过滤器使用倒排索引。

注意
geo_point 类型的字段可以包含多个地理坐标点,但是针对经度纬度分别索引的这种优化方式只对包含单个坐标点的字段有效。



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2019-1-8 09:39:51 | 显示全部楼层
真是难得给力的帖子啊。
发表于 2019-1-8 14:30:48 | 显示全部楼层
强烈支持楼主ing……
发表于 2019-1-8 16:43:29 | 显示全部楼层
感恩无私的分享与奉献
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-12-23 00:37

© 2014-2021

快速回复 返回顶部 返回列表