我可以通过附近的多边形查询带有边界多边形的DocumentDB文档吗?

时间:2015-10-07 12:24:32

标签: c# linq azure azure-cosmosdb spatial-query

与许多人一样,两个月前我在Microsoft Azure团队announced support for spatial queries in DocumentDB时感到很兴奋。特别是,DocumentDB支持ST_DISTANCE查询,该查询允许您根据文档与另一个几何体的距离来查询文档。使用LINQ的示例可以在Azure documentation

中找到
foreach (UserProfile user in client.CreateDocumentQuery<UserProfile>(collection.SelfLink)
    .Where(u => u.ProfileType == "Public" && a.Location.Distance(new Point(32.33, -4.66)) < 30000))
{
    Console.WriteLine("\t" + user);
}

在此示例中,查询位于两点之间。然而,文档谈到了几何形状之间的距离&#34;和&#34;点表达式&#34;让我认为可以通过除点之外的几何查询。

我的文档有一个边界多边形作为属性。我想通过它们彼此接近来查询这些文档。我尝试过以下方法:

DocumentClient Client = Connection.Client;

var nearbyItems = Client
    .CreateDocumentQuery<T>(Collection.DocumentsLink)
    .Where(x.BoundingPolygon.Distance(adjacentPolygon) < 1000)
    .ToList();

我已尝试使用以下相邻且非常简单的边界多边形:

文档多边形:

"geometry": {
  "type": "Polygon",
  "coordinates": [[
    [-33,18],[-34,18],[-34,19],[-33,19],[-33,18]
    ]]
  }

AdjacentPolygon:

"geometry": {
  "type": "Polygon",
  "coordinates": [[
    [-33,19],[-34,19],[-34,20],[-33,20],[-33,19]
    ]]
  }

但即使将距离提高到数千公里,该文件也不会从我的查询中返回。

是否可以通过靠近另一个边界多边形来查询带有边界多边形的DocumentDB文档?

1 个答案:

答案 0 :(得分:1)

没有。 ST_DISTANCE旨在仅处理两个点表达式。 ST_WITHIN将使用点表达式和多边形。

要找到两个多边形之间的最小距离,您必须比较一个多边形上每个点的点距离与另一个多边形上的每个点的距离,但我发现您经常不需要精确度,即使你这样做,在进行细节计算之前先得到一个近似答案是有意义的。

作为近似答案的示例,您可以将一个多边形的中心与其他多边形的中心进行比较。 GeoLib是一个具有getCenter()功能的JavaScript库。从那里提取代码并将其放在您编写多边形时调用的存储过程中(您必须为现有多边形编写迁移)。在该存储过程中,调用getCenter()函数并将结果存储在与多边形相同的文档中的另一个字段中。然后对查询中的这些中心点使用ST_DISTANCE函数来查找附近的所有其他多边形。