GetNodeByPoint — Hittar nod-id för en nod vid en punktposition.
bigint GetNodeByPoint(
varchar atopology, geometry apoint, float8 tol1)
;
Hämtar id för en nod på en punktplats.
Funktionen returnerar ett heltal (id-node) givet en topologi, en POINT och en tolerans. Om tolerans = 0 betyder det exakt intersektion, annars hämtas noden från ett intervall.
Om en punkt
inte korsar en nod returneras 0 (noll).
Om use tolerance > 0 och det finns mer än en nod nära punkten kastas ett undantag.
![]() |
|
Om toleransen = 0 använder funktionen ST_Intersects, annars används ST_DWithin. |
Utförs av GEOS-modulen.
Tillgänglighet: 2.0.0
I dessa exempel används kanter som vi skapade i AddEdge
SELECT topology.GetNodeByPoint('ma_topo',geom, 1) As nearnode FROM ST_GeomFromEWKT('SRID=26986;POINT(227591.9 893900.4)') As geom; nearnode ---------- 2
SELECT topology.GetNodeByPoint('ma_topo',geom, 1000) As too_much_tolerance FROM ST_GeomFromEWKT('SRID=26986;POINT(227591.9 893900.4)') As geom; ----get error-- ERROR: Two or more nodes found