Skip to content

适用虚谷数据库版本

v12.9



适用虚谷数据库版本

v12.9


ST_DISTANCECPA

📄字数 517
👁️阅读量 加载中...

功能描述

返回两条轨迹在它们最接近的相交点处的距离(在二维空间中)。

语法格式

sql
DOUBLE ST_CLOSESTPOINTOFAPPROACH(GEOMETRY track1, GEOMETRY track2);

参数说明

  • track1:第一个目标轨迹对象。
  • track2:第二个目标轨迹对象。

函数返回类型

DOUBLE 类型

使用说明

  1. 输入必须是经 ST_IsValidTrajectory 检查的有效轨迹。
  2. 如果轨迹在其 M 范围内不重叠,则返回 NULL。
  3. 该函数支持 3d 并且不会丢失 z-index。

示例

返回 10:00 and 11:00 之间,两轨迹的最近距离:

sql
SQL> WITH inp AS ( SELECT
            ST_AddMeasure('LINESTRING Z (0 0 0, 10 0 5)'::geometry,
              UNIX_TIMESTAMP('2015-05-26 10:00'),
              UNIX_TIMESTAMP('2015-05-26 11:00')
            ) a,
            ST_AddMeasure('LINESTRING Z (0 2 10, 12 1 2)'::geometry,
              UNIX_TIMESTAMP('2015-05-26 10:00'),
              UNIX_TIMESTAMP('2015-05-26 11:00')
            ) b
          )
          SELECT ST_DistanceCPA(a,b) distance FROM inp;

+--------------+
|   DISTANCE   |
+--------------+
| 1.965215e+00 |
+--------------+