本文整理匯總了Java中org.elasticsearch.index.query.QueryBuilders.geoShapeQuery方法的典型用法代碼示例。如果您正苦於以下問題:Java QueryBuilders.geoShapeQuery方法的具體用法?Java QueryBuilders.geoShapeQuery怎麽用?Java QueryBuilders.geoShapeQuery使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.elasticsearch.index.query.QueryBuilders
的用法示例。
在下文中一共展示了QueryBuilders.geoShapeQuery方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: testShapeFilterWithRandomGeoCollection
import org.elasticsearch.index.query.QueryBuilders; //導入方法依賴的package包/類
public void testShapeFilterWithRandomGeoCollection() throws Exception {
// Create a random geometry collection.
GeometryCollectionBuilder gcb = RandomShapeGenerator.createGeometryCollection(random());
logger.info("Created Random GeometryCollection containing {} shapes", gcb.numShapes());
client().admin().indices().prepareCreate("test").addMapping("type", "location", "type=geo_shape,tree=quadtree")
.execute().actionGet();
XContentBuilder docSource = gcb.toXContent(jsonBuilder().startObject().field("location"), null).endObject();
client().prepareIndex("test", "type", "1").setSource(docSource).setRefreshPolicy(IMMEDIATE).get();
ShapeBuilder filterShape = (gcb.getShapeAt(randomIntBetween(0, gcb.numShapes() - 1)));
GeoShapeQueryBuilder filter = QueryBuilders.geoShapeQuery("location", filterShape);
filter.relation(ShapeRelation.INTERSECTS);
SearchResponse result = client().prepareSearch("test").setTypes("type").setQuery(QueryBuilders.matchAllQuery())
.setPostFilter(filter).get();
assertSearchResponse(result);
assertHitCount(result, 1);
}
示例2: main
import org.elasticsearch.index.query.QueryBuilders; //導入方法依賴的package包/類
public static void main(String[] args) {
/* QueryBuilder qb1 = QueryBuilders.matchQuery("a","b");
System.out.println(qb1.toString());*/
String json="{\"query\":{\"match_all\":{}},\"filter\":{\"geo_shape\":{\"geometry\":{\"relation\":\"CONTAINS\",\"shape\":{\"coordinates\":[116.402257,39.914548],\"type\":\"point\"}}}}}";
QueryBuilder qb= QueryBuilders.matchAllQuery();
//System.out.println(qb.toString());
SearchSourceBuilder searchSourceBuilder=new SearchSourceBuilder();
searchSourceBuilder.query(qb);
// System.out.println(searchSourceBuilder.toString());
ShapeBuilder shapeBuilder= ShapeBuilder.newPoint(new Coordinate(116.402257,39.914548));
QueryBuilder qb2= QueryBuilders.geoShapeQuery("geometry",shapeBuilder, ShapeRelation.CONTAINS);
System.out.println(qb2.toString());
//searchSourceBuilder.postFilter(qb2);
QueryBuilder qb3= QueryBuilders.boolQuery().must(qb).filter(qb2);
searchSourceBuilder.query(qb3);
System.out.println(qb3.toString());
System.out.println(searchSourceBuilder.toString());
QueryBuilder qb4= QueryBuilders.boolQuery().must(qb).must(qb2);
System.out.println(qb4.toString());
SortBuilder sort= SortBuilders.geoDistanceSort("pin.location") .point(40, -70).
unit(DistanceUnit.fromString(DistanceUnit.KILOMETERS.toString())).order(SortOrder.DESC);
/* QueryBuilder qb5 = QueryBuilders.geoDistanceQuery("pin.location")
.point(40, -70)
.distance(400, DistanceUnit.fromString(DistanceUnit.KILOMETERS.toString()))
.geoDistance(GeoDistance.ARC);
System.out.println(qb5.toString());
*/
searchSourceBuilder.sort(sort);
System.out.println(searchSourceBuilder.toString());
//QueryBuilder qb3=QueryBuilders.filteredQuery(null,qb2);
//QueryBuilder qb4=QueryBuilders.filteredQuery(qb,qb2);
//searchSourceBuilder.query(qb3.toString());
// searchSourceBuilder.query(qb4);
// System.out.println(qb4.toString());
//System.out.println(searchSourceBuilder.toString());
// System.out.println(qb.toString());
/* QueryBuilder qb2 = QueryBuilders.geoBoundingBoxQuery("pin.location")
.topLeft(40.73, -74.1)
.bottomRight(40.717, -73.99);
//String strstr= JSON.toJSONString(qb2);
System.out.println(qb2.toString());
System.out.println("1111111");*/
}
示例3: t_queryByEsQueryDo2
import org.elasticsearch.index.query.QueryBuilders; //導入方法依賴的package包/類
@org.junit.Test
public void t_queryByEsQueryDo2()throws Exception {
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
QueryBuilder qb = QueryBuilders.matchAllQuery();
searchSourceBuilder.query(qb);
ShapeBuilder shapeBuilder = ShapeBuilder.newPoint(new Coordinate(116.402257, 39.914548));
QueryBuilder qb2 = QueryBuilders.geoShapeQuery("geometry", shapeBuilder, ShapeRelation.CONTAINS);
QueryBuilder qb3 = QueryBuilders.boolQuery().must(qb).filter(qb2);
searchSourceBuilder.query(qb3);
iEsQueryDao.query(searchSourceBuilder,"twitter","user","user2");
/*logger.info(JSON.toJSONString(es));
Assert.assertNotEquals("1", es.getStatus());*/
}
示例4: testShapeFilterWithDefinedGeoCollection
import org.elasticsearch.index.query.QueryBuilders; //導入方法依賴的package包/類
public void testShapeFilterWithDefinedGeoCollection() throws Exception {
createIndex("shapes");
client().admin().indices().prepareCreate("test").addMapping("type", "location", "type=geo_shape,tree=quadtree")
.execute().actionGet();
XContentBuilder docSource = jsonBuilder().startObject().startObject("location")
.field("type", "geometrycollection")
.startArray("geometries")
.startObject()
.field("type", "point")
.startArray("coordinates")
.value(100.0).value(0.0)
.endArray()
.endObject()
.startObject()
.field("type", "linestring")
.startArray("coordinates")
.startArray()
.value(101.0).value(0.0)
.endArray()
.startArray()
.value(102.0).value(1.0)
.endArray()
.endArray()
.endObject()
.endArray()
.endObject().endObject();
client().prepareIndex("test", "type", "1")
.setSource(docSource).setRefreshPolicy(IMMEDIATE).get();
GeoShapeQueryBuilder filter = QueryBuilders.geoShapeQuery(
"location",
ShapeBuilders.newGeometryCollection()
.polygon(
ShapeBuilders.newPolygon(new CoordinatesBuilder().coordinate(99.0, -1.0).coordinate(99.0, 3.0).coordinate(103.0, 3.0).coordinate(103.0, -1.0)
.coordinate(99.0, -1.0)))).relation(ShapeRelation.INTERSECTS);
SearchResponse result = client().prepareSearch("test").setTypes("type").setQuery(QueryBuilders.matchAllQuery())
.setPostFilter(filter).get();
assertSearchResponse(result);
assertHitCount(result, 1);
filter = QueryBuilders.geoShapeQuery(
"location",
ShapeBuilders.newGeometryCollection().polygon(
ShapeBuilders.newPolygon(new CoordinatesBuilder().coordinate(199.0, -11.0).coordinate(199.0, 13.0).coordinate(193.0, 13.0).coordinate(193.0, -11.0)
.coordinate(199.0, -11.0)))).relation(ShapeRelation.INTERSECTS);
result = client().prepareSearch("test").setTypes("type").setQuery(QueryBuilders.matchAllQuery())
.setPostFilter(filter).get();
assertSearchResponse(result);
assertHitCount(result, 0);
filter = QueryBuilders.geoShapeQuery("location", ShapeBuilders.newGeometryCollection()
.polygon(ShapeBuilders.newPolygon(new CoordinatesBuilder().coordinate(99.0, -1.0).coordinate(99.0, 3.0).coordinate(103.0, 3.0).coordinate(103.0, -1.0).coordinate(99.0, -1.0)))
.polygon(
ShapeBuilders.newPolygon(new CoordinatesBuilder().coordinate(199.0, -11.0).coordinate(199.0, 13.0).coordinate(193.0, 13.0).coordinate(193.0, -11.0)
.coordinate(199.0, -11.0)))).relation(ShapeRelation.INTERSECTS);
result = client().prepareSearch("test").setTypes("type").setQuery(QueryBuilders.matchAllQuery())
.setPostFilter(filter).get();
assertSearchResponse(result);
assertHitCount(result, 1);
// no shape
filter = QueryBuilders.geoShapeQuery("location", ShapeBuilders.newGeometryCollection());
result = client().prepareSearch("test").setTypes("type").setQuery(QueryBuilders.matchAllQuery())
.setPostFilter(filter).get();
assertSearchResponse(result);
assertHitCount(result, 0);
}