ST_CPAWITHIN
📄字数 540
👁️阅读量 加载中...
功能描述
测试两个轨迹最近距离是否在指定距离内。
语法格式
sql
BOOLEAN ST_CPAWITHIN(GEOMETRY track1, GEOMETRY track2, DOUBLE dist);参数说明
- track1:第一个目标轨迹对象。
- track2:第二个目标轨迹对象。
- dist:目标距离。
函数返回类型
BOOLEAN 类型
使用说明
- 输入必须是经 ST_IsValidTrajectory 检查的有效轨迹。
- 如果轨迹在其 M 范围内不重叠,则返回 FALSE。
- 该函数支持 3d 并且不会丢失 z-index。
示例
返回 10:00 and 11:00 之间,两轨迹的最近距离是否小于 2:
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_CPAWithin(a,b,2), ST_DistanceCPA(a,b) distance FROM inp;
+-------+--------------+
| EXPR1 | DISTANCE |
+-------+--------------+
| T | 1.965215e+00 |
+-------+--------------+