Name

GetNodeByPoint — Hittar nod-id för en nod vid en punktposition.

Synopsis

bigint GetNodeByPoint(varchar atopology, geometry apoint, float8 tol1);

Beskrivning

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.

[Note]

Om toleransen = 0 använder funktionen ST_Intersects, annars används ST_DWithin.

Utförs av GEOS-modulen.

Tillgänglighet: 2.0.0

Exempel

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