ST_RemoveRepeatedPoints — 返回一个几何图形的版本,其中删除了重复的点。
geometry ST_RemoveRepeatedPoints(
geometry geom, float8 tolerance)
;
返回给定几何图形的版本,其中删除了重复的连续点。此函数仅处理(多)线串、(多)多边形和多点,但可以使用任何类型的几何图形调用。 GeometryCollection 的元素会被单独处理。线串的端点会被保留。
如果提供了 tolerance
参数,则认为彼此在公差距离内的顶点是重复的。
增强功能:3.2.0
可用性:2.2.0
此函数支持多面体表面。
此函数支持 3D,并且不会删除 z 索引。
SELECT ST_AsText( ST_RemoveRepeatedPoints( 'MULTIPOINT ((1 1), (2 2), (3 3), (2 2))')); ------------------------- MULTIPOINT(1 1,2 2,3 3)
SELECT ST_AsText( ST_RemoveRepeatedPoints( 'LINESTRING (0 0, 0 0, 1 1, 0 0, 1 1, 2 2)')); --------------------------------- LINESTRING(0 0,1 1,0 0,1 1,2 2)
示例: 集合元素会被单独处理。
SELECT ST_AsText( ST_RemoveRepeatedPoints( 'GEOMETRYCOLLECTION (LINESTRING (1 1, 2 2, 2 2, 3 3), POINT (4 4), POINT (4 4), POINT (5 5))')); ------------------------------------------------------------------------------ GEOMETRYCOLLECTION(LINESTRING(1 1,2 2,3 3),POINT(4 4),POINT(4 4),POINT(5 5))
示例: 使用距离容差删除重复点。
SELECT ST_AsText( ST_RemoveRepeatedPoints( 'LINESTRING (0 0, 0 0, 1 1, 5 5, 1 1, 2 2)', 2)); ------------------------- LINESTRING(0 0,5 5,2 2)