2

我正在尝试构建一个 CQL 查询,以便在我的 spartial 数据库中找到某个形状。

我希望我的查询返回具有最大交叉点的形状。我的想法是设置 LIMIT=1 和 sortBy 交集。

如果您看到附加的屏幕截图,我希望我的查询返回以下内容:

从左到右的三角形

  • 过滤器1 --> 黄色形状
  • 过滤器2 --> 黄色形状
  • 过滤器3 --> 绿色形状

有什么办法可以解决我的问题吗?

到目前为止,我正在使用以下代码:

    Filter f1 = CQL.toFilter("INTERSECTS(the_geom, POLYGON((10.07051 53.23476, 10.08143 53.23512, 10.07596 53.22838, 10.07051 53.23476)))");
    Filter f2 = CQL.toFilter("INTERSECTS(the_geom, POLYGON((10.06268 53.23756, 10.06889 53.23865, 10.06260 53.24903, 10.06268 53.23756)))");
    Filter f3 = CQL.toFilter("INTERSECTS(the_geom, POLYGON((10.08146 53.24462, 10.09540 53.24761, 10.08247 53.26067, 10.08146 53.24462)))");

    Query query = new Query( typeName, f3);
    query.setMaxFeatures(1);
    source.getFeatures(query);

    SimpleFeatureCollection features = source.getFeatures(query);
    SimpleFeatureIterator it = features.features();
    while (it.hasNext()){
        SimpleFeature sf = it.next();
        System.out.println(sf.getAttributes());
    }

在此处查看屏幕截图

4

0 回答 0