Como encontrar o ponto mais próximo usando a função PostGIS?

8

quadro 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

quadro B:

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

Gostaria de encontrar o (s) ponto (s) mais próximo (s) de cada ponto (ponto inicial e final da tabela A) e comparar com todos os pontos com o mesmo 'código' na tabela B?

Qual é a melhor consulta da função PostGIS / PostgreSQL para resolver isso? O que eu tentei são ..

ST_Distance_Spheroid e ST_DWithin e ST_Distance

Mas não tenho idéia de como combiná-los em uma única consulta.

user9404
fonte

Respostas:

9

Talvez algo assim (presumo que você tenha alguma coluna de chave primária "id" em cada tabela):

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
);
Micha
fonte