ST_CPAWithin — Testar om den närmaste punkten för två banor ligger inom det angivna avståndet.
boolean ST_CPAWithin(
geometry track1, geometry track2, float8 dist)
;
Testar om två rörliga objekt någonsin har varit närmare än det angivna avståndet.
Ingångarna måste vara giltiga banor som kontrolleras av ST_IsValidTrajectory. False returneras om banorna inte överlappar varandra i sina M-områden.
Tillgänglighet: 2.2.0
Denna funktion stöder 3d och kommer inte att tappa z-index.
WITH inp AS ( SELECT ST_AddMeasure('LINESTRING Z (0 0 0, 10 0 5)'::geometry, extract(epoch from '2015-05-26 10:00'::timestamptz), extract(epoch from '2015-05-26 11:00'::timestamptz) ) a, ST_AddMeasure('LINESTRING Z (0 2 10, 12 1 2)'::geometry, extract(epoch from '2015-05-26 10:00'::timestamptz), extract(epoch from '2015-05-26 11:00'::timestamptz) ) b ) SELECT ST_CPAWithin(a,b,2), ST_DistanceCPA(a,b) distance FROM inp; st_cpawithin | distance --------------+------------------ t | 1.96521473776207