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