当前位置: 首页 > news >正文

Elasticsearch:Geoshape query

Geoshape 查询可以用于过滤使用 geo_shape 或 geo_point 类型索引的文档。

geo_shape 查询使用与 geo_shape 或 geo_point 映射相同的索引来查找具有与查询形状相关的形状的文档,并使用指定的空间关系:相交(intersect)、包含(contained)、包含(within)或不相交 (disjoin)。

该查询支持两种定义查询形状的方法,一种是提供整个形状定义,另一种是引用在另一个索引中预先索引的形状的名称。 下面通过示例定义了这两种格式。

内联形状定义

与 geo_point 类型类似,geo_shape 查询使用 GeoJSON 来表示形状。有关如何制作 GeoJSON,请参考我的另外一篇文章 “Elasticsearch:如何制作 GeoJSON 文件并进行地理位置搜索”。

sample.json

{"type": "FeatureCollection","features": [{"type": "Feature","properties": {},"geometry": {"type": "Polygon","coordinates": [[[ 13.0,52.0 ],[14.0,52.0],[14.0,53.0],[13.0,53.0],[13.0,52.0]  ]]}}
]
}

给定以下索引,其中位置作为 geo_shape 字段:

PUT /example
{"mappings": {"properties": {"location": {"type": "geo_shape"}}}
}POST /example/_doc?refresh
{"name": "Wind & Wetter, Berlin, Germany","location": {"type": "point","coordinates": [ 13.400544, 52.530286 ]}
}

以下查询将使用 Elasticsearch 的信封 GeoJSON 扩展查找点:

GET /example/_search
{"query": {"bool": {"must": {"match_all": {}},"filter": {"geo_shape": {"location": {"shape": {"type": "envelope","coordinates": [ [ 13.0, 53.0 ], [ 14.0, 52.0 ] ]},"relation": "within"}}}}}
}

类似地,可以在 geo_point 字段上查询上述查询。

PUT /example_points
{"mappings": {"properties": {"location": {"type": "geo_point"}}}
}PUT /example_points/_doc/1?refresh
{"name": "Wind & Wetter, Berlin, Germany","location": [13.400544, 52.530286]
}

使用相同的查询,将返回具有匹配 geo_point 字段的文档。

GET /example_points/_search
{"query": {"bool": {"must": {"match_all": {}},"filter": {"geo_shape": {"location": {"shape": {"type": "envelope","coordinates": [ [ 13.0, 53.0 ], [ 14.0, 52.0 ] ]},"relation": "intersects"}}}}}
}

预索引形状

该查询还支持使用已在另一个索引中建立索引的形状。 当你有预定义的形状列表并且你想要使用逻辑名称(例如 New Zealand 新西兰)引用该列表而不是每次都提供坐标时,这特别有用。 在这种情况下,只需提供:

  • id - 包含预索引形状的文档的 ID。
  • index - 预索引形状所在的索引的名称。 默认为 shapes。
  • path - 指定为包含预索引形状的路径的字段。 默认为 shape。
  • routing - 形状文档的路由(如果需要)。

以下是将过滤器与预索引形状一起使用的示例:

PUT /shapes
{"mappings": {"properties": {"location": {"type": "geo_shape"}}}
}PUT /shapes/_doc/deu
{"location": {"type": "envelope","coordinates" : [[13.0, 53.0], [14.0, 52.0]]}
}GET /example/_search
{"query": {"bool": {"filter": {"geo_shape": {"location": {"indexed_shape": {"index": "shapes","id": "deu","path": "location"}}}}}}
}

空间关系

以下是搜索地理字段时可用的空间关系运算符的完整列表:

  • INTERSECTS -(默认)返回 geo_shape 或 geo_point 字段与查询几何图形相交的所有文档。
  • DISJOINT - 返回其 geo_shape 或 geo_point 字段与查询几何图形没有任何共同点的所有文档。
  • WITHIN - 返回 geo_shape 或 geo_point 字段位于查询几何图形内的所有文档。 不支持线几何形状。
  • CONTAINS - 返回 geo_shape 或 geo_point 字段包含查询几何图形的所有文档。

忽略未映射的

当设置为 true 时,ignore_unmapped 选项将忽略未映射的字段,并且不会匹配此查询的任何文档。 当查询可能具有不同映射的多个索引时,这非常有用。 当设置为 false(默认值)时,如果字段未映射,查询将引发异常。

注意

当数据在 geo_shape 字段中作为形状数组进行索引时,这些数组将被视为一个形状。 因此,以下请求是等效的。

PUT /test/_doc/1
{"location": [{"coordinates": [46.25,20.14],"type": "point"},{"coordinates": [47.49,19.04],"type": "point"}]
}
PUT /test/_doc/1
{"location":{"coordinates": [[46.25,20.14],[47.49,19.04]],"type": "multipoint"}
}

geo_shape 查询假定 geo_shape 字段使用默认方向 RIGHT(逆时针)。 请参见 Polygon orientation。

相关文章:

  • 基于YOLOv8深度学习的水稻叶片病害智能诊断系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战
  • anaconda+pytorch+pycharm安装总结
  • M1芯片MAC 安装MySQL、Nacos遇到的问题
  • VUE开发记录
  • CTFHub:web-LD_PRELOAD-WP
  • 担心信息泄露被恶意申贷,查大数据报告有用吗?
  • linux中的makefile
  • -1- Python环境安装
  • C++模版初阶
  • 如何在 Golang 中使用 crypto/ed25519 进行数字签名和验证
  • 大数据信用报告查询费用一般要多少钱?
  • 幻兽帕鲁能在Mac上运行吗?幻兽帕鲁Palworld新手攻略
  • 【ArcGIS微课1000例】0100:ArcGIS for CAD软件下载与安装(附安装包)
  • 【数据分享】1929-2023年全球站点的逐月降雪深度数据(Shp\Excel\免费获取)
  • golang网络编程day4
  • (ckeditor+ckfinder用法)Jquery,js获取ckeditor值
  • Akka系列(七):Actor持久化之Akka persistence
  • EOS是什么
  • Git学习与使用心得(1)—— 初始化
  • Golang-长连接-状态推送
  • Java到底能干嘛?
  • Java的Interrupt与线程中断
  • vue的全局变量和全局拦截请求器
  • windows下使用nginx调试简介
  • 从tcpdump抓包看TCP/IP协议
  • 大数据与云计算学习:数据分析(二)
  • 发布国内首个无服务器容器服务,运维效率从未如此高效
  • 解析 Webpack中import、require、按需加载的执行过程
  • 两列自适应布局方案整理
  • 试着探索高并发下的系统架构面貌
  • 适配mpvue平台的的微信小程序日历组件mpvue-calendar
  • 微信小程序开发问题汇总
  • ## 临床数据 两两比较 加显著性boxplot加显著性
  • (14)Hive调优——合并小文件
  • (Python) SOAP Web Service (HTTP POST)
  • (rabbitmq的高级特性)消息可靠性
  • (二)斐波那契Fabonacci函数
  • (分享)自己整理的一些简单awk实用语句
  • (附源码)ssm本科教学合格评估管理系统 毕业设计 180916
  • (附源码)ssm学生管理系统 毕业设计 141543
  • (论文阅读23/100)Hierarchical Convolutional Features for Visual Tracking
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (学习日记)2024.04.04:UCOSIII第三十二节:计数信号量实验
  • (状压dp)uva 10817 Headmaster's Headache
  • *** 2003
  • **python多态
  • .a文件和.so文件
  • .jks文件(JAVA KeyStore)
  • .NET Core 控制台程序读 appsettings.json 、注依赖、配日志、设 IOptions
  • .Net 转战 Android 4.4 日常笔记(4)--按钮事件和国际化
  • .NET的数据绑定
  • .NET教程 - 字符串 编码 正则表达式(String Encoding Regular Express)
  • .net最好用的JSON类Newtonsoft.Json获取多级数据SelectToken
  • @hook扩展分析
  • [ C++ ] STL_stack(栈)queue(队列)使用及其重要接口模拟实现