8 votos

¿Cómo encontrar el punto más cercano utilizando la función PostGIS?

Tabla A:

lat | long | the_geom | code | sign 
13.8433095 | 100.6360357 | 0101000020E61.... | ABC | start_point
13.7544738 | 100.5459646 | 0101000020E6..... | ABC | end_point
13.4124215 | 100.6232332 | 0101000020E61.... | DEF | start_point
13.2423438 | 100.2324426 | 0101000020E6..... | DEF | end_point

Tabla B:

lat | long | the_geom | code    
13.7546285 | 100.5458729 | 0101000020E.... | ABC    
13.7546698 | 100.5458513 | 0101000020E.... | ABC
13.7547107 | 100.5458233 | 0101000020E.... | DEF    
...

Me gustaría encontrar el punto o puntos más cercanos de cada punto (punto inicial y final de la tabla A) y compararlos con todos los puntos con el mismo "código" de la tabla B.

¿Cuál es la mejor función PostGIS/consulta PostgreSQL para resolver este problema? Lo que he intentado son

ST_Distance_Spheroid y ST_DWithin y ST_Distance

Pero no tengo ni idea de cómo combinarlos en una sola consulta.

9voto

GriffinHeart Puntos 187

Tal vez algo como esto (voy a suponer que tiene alguna columna de clave primaria "id" en cada tabla):

SELECT A.id, A.code AS Code, A.sign AS Sign, B.id, 
   ST_Distance(A.geom, B.geom) AS Distance 
FROM Table_A AS A, Table_B AS B
WHERE A.id IN ( 
   SELECT X.id
   FROM TableA as X, TableB as Y
-- Here's the important part: refer to the A table **outside** of the subquery
   WHERE X.code=Y.code AND X.id=A.id
-- and use ORDER BY ... LIMIT 1 to get the closest point
   ORDER BY ST_Distance(X.geom, Y.geom) ASC LIMIT 1
);

i-Ciencias.com

I-Ciencias es una comunidad de estudiantes y amantes de la ciencia en la que puedes resolver tus problemas y dudas.
Puedes consultar las preguntas de otros usuarios, hacer tus propias preguntas o resolver las de los demás.

Powered by:

X