Oracle Spatial 几何对象之间的距离

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 还能在三维物体上使用。如计算一条直升机轨迹和最近的建筑物之间的距离。

 

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值