2

我正在尝试对 Querydsl 使用 INTERSECTS 操作:

PolygonPath<Polygon> polygonpath = new PolygonPath<Polygon>(entityPath, "location");
Geometry geometry = Wkt.fromWkt("POLYGON ((30 10, 40 40, 20 40, 10 20, 30 10))");
BooleanExpression intersectsExpression = polygonpath.intersects(geometry);

当生成 BooleanExpression 我收到以下消息:

unknown operation with operator com.mysema.query.spatial.SpatialOps#INTERSECTS and args [entity.location, POLYGON((30 10,40 40,20 40,10 20,30 10))]

我正在使用 HibernateSpatial.. 然后我正在尝试执行以下操作:

根据您的 HibernateSpatialSupport 创建我自己的类,以创建有效的相交操作以在 HibernateSpatial 上使用。

我创建了一个 HibernateSpatialOps:

private static final String NS = HibernateSpatialOps.class.getName(); public static final Operator<Object> INTERSECTS = new OperatorImpl<Object>( NS, "intersects({0}, {1})");

当我使用相交操作生成 BooleanExpression 时,会出现以下消息:

unknown operation with operator org.project1.querydsl.HibernateSpatialOps#intersects({0}, {1}) and args [entity.location, POLYGON ((-0.948944091796875 39.49052944781087, -0.4988479614257812 39.49052944781087, -0.4988479614257812 39.39030533696812, -0.948944091796875 39.39030533696812, -0.948944091796875 39.49052944781087))]

你能帮助我吗?

此致,

4

1 回答 1

0

Querydsl 中尚不提供 Hibernate Spatial 支持。随意通过拉取请求进一步推动它。

于 2014-09-09T16:15:22.673 回答