gpt4 book ai didi

postgresql - POSTGRES POSTGIS sfcgal - st_3darea 不工作

转载 作者:行者123 更新时间:2023-12-04 07:23:04 25 4
gpt4 key购买 nike

我对 st_3darea、st_3dintersection 等 sfcgal 扩展方法有问题,使用多多边形。
当多边形接触时,我收到一个错误,说多边形相交。
这两个三角形显然不是相交只是相交:

SELECT st_3darea(ST_GeomFromText(
'MULTIPOLYGON Z (((1 0 0, 1 1 0, 0 1 1, 1 0 0)),
((1 0 0, 0 1 1, 0 0 1, 1 0 0)))'));

但我有一个错误:
ERROR:  MultiPolygon is invalid : intersection between Polygon 0 and 1 : MULTIPOLYGON(((1/1 0/1 0/1,1/1 1/1 0/1,0/1 1/1 1/1,1/1 0/1 0/1)),((1/1 0/1 0/1,0/1 1/1 1/1,0/1 0/1 1/1,1/1 0/1 0/1)))
SQL state: XX000
请帮忙。
任何建议都欢迎

最佳答案

您的 MULTIPOLYGON无效,因为多边形相交。使用 ST_MakeValid为了克服这个问题:

SELECT 
ST_3DArea(
ST_MakeValid('MULTIPOLYGON Z (((1 0 0, 1 1 0, 0 1 1, 1 0 0)),
((1 0 0, 0 1 1, 0 0 1, 1 0 0)))'::geometry));

st_3darea
------------------
1.41421356237309
(1 row)
正如@JGH 所指出的(见评论):

ST_Overlaps, ST_Touches, ST_Within all imply spatial intersection. If any of the aforementioned returns true, then the geometries also spatially intersect. Disjoint implies false for spatial intersection.

关于postgresql - POSTGRES POSTGIS sfcgal - st_3darea 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68379566/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com