Elasticsearch-多边形范围查询(8.x)
创始人
2025-01-08 16:04:45
0

目录

一、字段设计

二、数据录入

三、查询语句

四、Java代码实现


开发版本详见:Elasticsearch-经纬度查询(8.x-半径查询)_es经纬度范围查询-CSDN博客

一、字段设计

PUT /aoi_points {   "mappings": {     "properties": {       "location": {         "type": "geo_shape"       }     }   } }

aoi_points是索引名称,location是字段名称,它将存储地理形状数据

二、数据录入

POST /aoi_points/_doc {   "location": {     "type": "point",     "coordinates": [-74.0060, 40.7128]   } }

三、查询语句

GET /aoi_points/_search {   "query": {     "bool": {       "filter": {         "geo_shape": {           "location": {             "shape": {               "type": "polygon",               "coordinates": [                 [                   [-74.02, 40.715],                   [-73.99, 40.715],                   [-73.99, 40.705],                   [-74.02, 40.705],                   [-74.02, 40.715]                 ]               ]             },             "relation": "within"           }         }       }     }   } }
  • location是存储地理位置的字段
  • shape定义了一个多边形区域,coordinates是一个数组,包含多边形顶点的坐标
  • relation指定了查询的地理空间关系,这里是within,表示查询多边形内部的点
  • 多边形的坐标点需要按顺序(通常是顺时针或逆时针)排列,形成一个闭合的多边形

四、Java代码实现

具体查询对象,可自行定义,本方法只提供思路,莫直接粘贴使用

        // 封装ES查询参数         BoolQuery.Builder boolQueryBuilder = new BoolQuery.Builder();         // AOI范围查询         ShapePO shapePo =                     new ShapePO().setType(GeographyType.POLYGON.getValue()).setCoordinates(poi.getAoi().getCoordinates());         // 多边形查询         GeoShapeQuery geoShapeQuery =             GeoShapeQuery.of(geoShape -> geoShape.field(PoiIndexConstant.LOCATION)                     .shape(s -> s.shape(JsonData.fromJson(JSONUtil.toJsonStr(shapePo))).relation(GeoShapeRelation.Within)))._toQuery().geoShape();         boolQueryBuilder.filter(f -> f.geoShape(geoShapeQuery));         int size = poi.getAoi().getCoordinates().get(0).size();          SearchRequest.Builder searchRequestBuilder = new SearchRequest.Builder();         searchRequestBuilder.index(esIndexProperties.getPoiIndexRead())                 .query(query -> query.bool(boolQueryBuilder.build()))                 .size(size);          // ES查询         SearchRequest searchRequest = searchRequestBuilder.build();         log.info("getSmallAttractionByPoiId query:{}", searchRequest.toString());         SearchResponse searchResponse = esUtil.queryDocument(searchRequest, PoiIndex.class);          if (searchResponse.hits().hits().isEmpty()) {             return List.of();         }         List smallAttractionDtoList = new ArrayList<>();         for (Hit hit : searchResponse.hits().hits()) {             // 业务处理         }

相关内容

热门资讯

7分钟窍要!福建天天开心辅助,... 7分钟窍要!福建天天开心辅助,九哥玩辅助(辅助)切实真的是有下载(哔哩哔哩)1、实时福建天天开心辅助...
第四分钟攻略!熟客温州游戏辅助... 第四分钟攻略!熟客温州游戏辅助器,新九哥脚本(辅助)其实是真的辅助器(哔哩哔哩)运熟客温州游戏辅助器...
第七分钟机巧!雀友会潮汕麻雀总... 第七分钟机巧!雀友会潮汕麻雀总部辅助,新鸿狐挂机(辅助)都是存在有软件(哔哩哔哩)1、雀友会潮汕麻雀...
第7分钟项目!中至江西插件,新... 第7分钟项目!中至江西插件,新道游拼十辅助器(辅助)一直真的有app(哔哩哔哩)1、新道游拼十辅助器...
第一分钟大纲!家家盘锦开挂,反... 第一分钟大纲!家家盘锦开挂,反杀新大厅辅助(辅助)真是存在有app(哔哩哔哩)1、操作简单,无需反杀...
第5分钟绝活儿!白银胡乐辅助脚... 第5分钟绝活儿!白银胡乐辅助脚本下载,新超圣辅助器(辅助)本来真的有工具(哔哩哔哩)1、白银胡乐辅助...
第六分钟指南书!皇豪互娱控制系... 第六分钟指南书!皇豪互娱控制系统app,新超圣正版辅助(辅助)切实是有插件(哔哩哔哩)所有人都在同一...
五分钟教程书!闲逸辅助器辅助下... 五分钟教程书!闲逸辅助器辅助下载,随意玩app下载开挂辅助(辅助)好像是真的工具(哔哩哔哩)1、这是...
第一分钟大纲!家家盘锦开挂,反... 第一分钟大纲!家家盘锦开挂,反杀新大厅辅助(辅助)真是有挂工具(哔哩哔哩)1.反杀新大厅辅助 选牌创...
第5分钟窍门!四川麻将血战到底... 第5分钟窍门!四川麻将血战到底定制插件辅助,新祥心挂机(辅助)原来真的有工具(哔哩哔哩)1、四川麻将...