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