ES 位置查询之geo_point

创建语句

PUT geo
{
  "mappings": {
    "properties": {
      "name":{
        "type": "keyword"
      },
      "location":{
        "type": "geo_point"
      }
    }
  }
}

其中 location字段的分词器类型为 geo_point, 这样就可以对地理相关的的数据进行操作, geo是地理的geographic单词缩写, 当为这个类型时数据格式为  "经度, 纬度"

geo_distance query

查询距离一个经纬点指定距离范围内的其它数据

geo_distance query可以查找在一个中心点指定范围内的地理点文档

GET geo/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match_all": {}
        }
      ],
      "filter": [
        {
          "geo_distance": {
            "distance": "200km",
            "location": {
              "lat": 39.08,
              "lon": 117.19
            }
          }
        }
      ]
    }
  }
}

查询距离位置点 lat(精度), lon(纬度) 200km的文档数据, 查询语句中的位置为天津, 最后得到结果为北京

按距离查询经纬点的远近排序

GET geo/_search
{
  "query": {
    "match_all": {}
  },
  "sort": [
    {
      "_geo_distance": {
        "location": "39.9088145109,116.3973999023",
        "unit": "km"
      }
    }
  ]
}

geo_bounding_box query 矩形范围查询

geo_bounding_box query用于查找落入指定的矩形内的地理坐标。查询中由两个点确定一个矩形

GET geo/_search
{
  "query": {
    "bool": {
      "must": [
        {"match_all": {}}
      ],
      "filter": [
        {"geo_bounding_box": {
          "location": {
            "top_left": {
              "lat": 38.48,
              "lon": 106.23
            },
            "bottom_right": {
              "lat": 28.68,
              "lon": 115.85
            }
          }
        }}
      ]
    }
  }
}

查询语句就如图片一样, geo_bounding_box 表示一个方框, 传入左上和右下两个坐标点确定一个矩形, 查出的结果就是 西安和郑州

 geo_polygon query 多边形范围内查询

这种是多个点确定一个图形范围, 不仅仅是三角形, 图片是三角形, N边形都可以

GET geo/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match_all": {}
        }
      ],
      "filter": [
        {
          "geo_polygon": {
            "location": {
              "points": [
                {
                  "lat": 40.84,
                  "lon": 111.75
                },
                {
                  "lat": 29.56,
                  "lon": 106.55
                },
                {
                  "lat": 31.23,
                  "lon": 121.47
                }
              ]
            }
          }
        }
      ]
    }
  }
}

查出来的结果为 西安和郑州

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Elasticsearch 中,可以使用地理位置字段来存储经纬度信息,并使用 Geo Distance Query 进行基于距离的查询。 以下是基于半径查询数据的 Java 代码示例: ```java import org.elasticsearch.index.query.QueryBuilder; import org.elasticsearch.index.query.QueryBuilders; import org.elasticsearch.search.builder.SearchSourceBuilder; import org.elasticsearch.search.sort.SortBuilders; import org.elasticsearch.search.sort.SortOrder; import org.elasticsearch.common.unit.DistanceUnit; import org.elasticsearch.common.geo.GeoDistance; import org.elasticsearch.common.geo.GeoPoint; // 设置查询条件 QueryBuilder queryBuilder = QueryBuilders .geoDistanceQuery("location") // 地理位置字段名称 .point(centerLat, centerLon) // 圆心经纬度 .distance(radius, DistanceUnit.KILOMETERS) // 半径,单位为公里 .geoDistance(GeoDistance.ARC); // 地理距离计算方式 // 设置排序规则 SearchSourceBuilder sourceBuilder = new SearchSourceBuilder(); sourceBuilder.sort(SortBuilders .geoDistanceSort("location", new GeoPoint(centerLat, centerLon)) .order(SortOrder.ASC) .unit(DistanceUnit.KILOMETERS) .point(new GeoPoint(centerLat, centerLon)) .geoDistance(GeoDistance.ARC)); // 执行查询 SearchResponse response = client.prepareSearch("my_index") .setTypes("my_type") .setQuery(queryBuilder) .setFrom(0) .setSize(10) .setFetchSource(true) .setSource(sourceBuilder) .execute() .actionGet(); ``` 在上述代码中,`location` 是地理位置字段名称,`centerLat` 和 `centerLon` 是圆心的经度和纬度,`radius` 是半径,单位为公里。`GeoDistance.ARC` 表示使用基于弧度的地理距离计算方式。 查询结果将按照距离圆心的距离升序排列。可以通过 `setFrom` 和 `setSize` 方法设置查询结果的分页。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值