Oracle Spatial 几何对象之间的距离

转载地址:https://blog.csdn.net/renshenguo123/article/details/83655745?utm_source=app&app_version=5.0.1&code=app_1562916241&uLinkId=usr1mkqgl919blen

SDO_WITHIN_DISTANCE 操作符是最简单的空间操作符之一,可以用它来进行临近分析,查询时该操作符能够使用空间索引,加快查询速度。如给定一个位置集,该操作符将从中返回在一个查询位置指定距离范围内的所有位置。

 

上图查询了距位置Q距离为d的所有点,于是对象A,B,C被检索出来,D,E被排除。

操作符语法如下:

SDO_WITHIN_DISTANCE
(
table_geo IN SDO_GEOMETRY,
query_geo IN SDO_GEOMETRY,
parameter_string IN VARCHAR2
)
='TRUE'
table_geo 为被检索表的SDO_GEOMETRY列
query_geo 为指定查询位置的SDO_GEOMETRY。可一个以是另一个表的一列、一个绑定变量或一个动态构造的对象。
parameter_string 指定参数 distance 及可选参数 unit(距离单位)
(PS : Oracle Spatial 规定操作符应永远和字符串‘TRUE’比较)

举例:查找商店周围50米范围内的所有客户

select ct.id, ct.name
from shops sh, customers ct
where sh.id=1
and SDO_WITHIN_DISTANCE(ct.location, sh.location,'distance=50 unit=M')='TRUE'
order by ct.id;
( unit 的单位值可以通过 MDSYS.SDO_DIST_UNITS 表选择)

函数 SDO_GEOM.SDO_DISTANCE,可以用来获得客户和商店之间的距离。该函数计算了两个几何体上的任意两点之间的最小距离。

SDO_GEOM.SDO_DISTANCE
(
geometry1 IN SDO_GEOMETRY,
geometry2 IN SDO_GEOMETRY,
tolerance IN NUMBER
[, params IN VARCHAR2 ]
)
RETURNS A NUMBER
geometry1 和 geometry2 表示SDO_GEOMETRY 对象。
tolerance 表示数据集的容差。 对于大地测量的数据,通常设置为 0.5 或者0.1(米)。
params 可选的参数。可指定返回距离的单位。
改写上述例子:

select ct.id, ct.name
from shops sh, customers ct
where sh.id=1
and SDO_GEOM.SDO_DISTANCE(ct.location, sh.location, 0.5, 'unit=METER') <=50
order by ct.id;
SDO_GEOM.SDO_DISTANCE 不能使用空间索引,所以在查询效率上比 SDO_WITHIN_DISTANCE 慢很多。

SDO_GEOM.SDO_DISTANCE 还能在三维物体上使用。如计算一条直升机轨迹和最近的建筑物之间的距离。
————————————————
版权声明:本文为CSDN博主「renshenguo123」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/renshenguo123/article/details/83655745

posted @ 2022-02-19 17:03  贩卖长江水  阅读(170)  评论(0编辑  收藏  举报