ST_ClosestPointOfApproach — 傳回兩個軌跡最接近點的度量值。
float8 ST_ClosestPointOfApproach(
geometry track1, geometry track2)
;
傳回沿著給定軌跡插值的點之間距離最小的最小度量值。
輸入必須是有效的軌跡,如同 ST_IsValidTrajectory 所檢查的一樣。如果軌跡的 M 範圍沒有重疊,則會傳回 Null。
若要取得計算度量值的實際點,請使用 ST_LocateAlong。
可用性: 2.2.0
這個函數支援 3D,並且不會捨棄 z 索引。
-- Return the time in which two objects moving between 10:00 and 11:00 -- are closest to each other and their distance at that point 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 ), cpa AS ( SELECT ST_ClosestPointOfApproach(a,b) m FROM inp ), points AS ( SELECT ST_GeometryN(ST_LocateAlong(a,m),1) pa, ST_GeometryN(ST_LocateAlong(b,m),1) pb FROM inp, cpa ) SELECT to_timestamp(m) t, ST_Distance(pa,pb) distance, ST_AsText(pa, 2) AS pa, ST_AsText(pb, 2) AS pb FROM points, cpa; t | distance | pa | pb -------------------------------+--------------------+--------------------------------------+---------------------------------------- 2015-05-26 10:45:31.034483-07 | 1.9603683315139542 | POINT ZM (7.59 0 3.79 1432662331.03) | POINT ZM (9.1 1.24 3.93 1432662331.03)