在我的数据库中,我存储了多边形。现在,我需要搜索特定半径内的所有多边形。 即使该多边形在该区域内仅是一小部分,也应将其包括在结果中(因此,一旦存在最小匹配,就存在匹配)。
做到这一点的最佳方法是什么?我一直在考虑创建另一个多边形并搜索与此相交的所有内容,但不知道这是否是有效方法?
答案 0 :(得分:0)
是的,我认为这是最好的方法。您可以使用ST_BUFFER创建多边形,然后可以使用ST_INTERSECT查找多边形是否会与多边形相交。
也许您也可以使用ST_DISTANCE来做到这一点。它将计算点到多边形的最小距离。
Select ST_DISTANCE(polygons,POINT(x, y)) as distance, polygon_id from your_polygon_table WHERE distance <= 10