GetNodeByPoint — Recherche l'identifiant d'un nœud à un point donné.
bigint GetNodeByPoint(varchar atopology, geometry apoint, float8 tol1);
Récupère l'identifiant d'un nœud à un point donné.
La fonction renvoie un entier (id-node) à partir d'une topologie, d'un POINT et d'une tolérance. Si tolérance = 0, il s'agit d'une intersection exacte, sinon le nœud est extrait d'un intervalle.
Si apoint n'intersecte pas un noeud, renvoie 0 (zéro).
Si la tolérance d'utilisation > 0 et qu'il y a plus d'un nœud près du point, une exception est levée.
|
|
|
Si la tolérance = 0, la fonction utilise ST_Intersects, sinon elle utilise ST_DWithin. |
Effectué par le module GEOS.
Disponibilité : 2.0.0
Ces exemples utilisent les arêtes que nous avons créées dans 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