Oracle Spacial(空间数据库)查询空间数据2

关系操作符

语法:

操作符OVERLAPBDYDISJOINT(geometry1,geometry2);

1、SDO_ANYINTERACT

2、SDO_CONTAINS

3、SDO_COVEREDBY

4、SDO_COVERS

5、SDO_EQUAL

6、SDO_INSIDE

7、SDO_ON

8、SDO_OVERLAPBDYDISJOINT

9、SDO_OVERLAPBDYINTERSECT

10、SDO_OVERLAPS

11、SDO_TOUCH

11g,支持3维的操作符有:

SDO_ANYINTERACT

SDO_FILTER

SDO_INSIDE (for solid geometries only)

SDO_NN

SDO_WITHIN_DISTANCE

 

为了获得最优的执行计划,当查询窗口(空间操作符的第二个参数)来

自于表时,请始终指定/*+ ordered */ 提示

 

SELECT/*+ ORDERED NO_INDEX(b IDX_I_POLE_S_FID) */

 b.name

  FROM i_exch_s a, i_pole_s b

 WHERE sdo_within_distance(b.gwm_geometry,

                          a.gwm_geometry,

                           'distance=5') = 'TRUE'

   AND a.gwm_fid IN(52062747,52062749)

   AND b.gwm_fid = 52598309;

空间函数与操作符的对比

1、 空间操作符使用的表必须有空间索引;

2、 空间操作符执行速度比函数快,因此可以采用操作符的情况下就使用操作符

3、使用空间操作符时,如果查询窗口来自于一个表,加上 /*+ORDERED */ 这个hint
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SDO_GEOM.SDO_BUFFER函数是Oracle Spatial中用于生成空间缓冲区的函数。它可以将输入几何对象沿着其边界放大或缩小指定距离,从而生成缓冲区。缓冲区可以是圆形、多边形或多线段。 函数语法如下: ``` SDO_GEOM.SDO_BUFFER( geometry IN SDO_GEOMETRY, distance IN NUMBER, tolerance IN NUMBER DEFAULT NULL, params IN VARCHAR2 DEFAULT NULL) RETURN SDO_GEOMETRY; ``` 参数说明: - geometry:输入的几何对象。可以是点、线、多边形等任何几何对象。 - distance:缓冲区距离。单位由params参数指定,默认为米。 - tolerance:缓冲区距离的精度。默认为NULL,表示使用默认精度。 - params:缓冲区距离的单位和其他参数。默认为NULL,表示使用默认参数。可以设置为'unit=KM'表示单位为千米,或者其他参数。 函数返回值为生成的缓冲区几何对象。 以下是一个示例代码,展示如何使用SDO_GEOM.SDO_BUFFER函数生成圆形缓冲区: ``` SELECT SDO_GEOM.SDO_BUFFER( SDO_GEOMETRY(2001, 8307, SDO_POINT_TYPE(-117.0, 34.0, NULL), NULL, NULL), 10, 0.005, 'unit=KM') as buffer FROM dual; ``` 在这个示例中,输入几何对象是一个点,经度为-117,纬度为34。缓冲区的距离为10公里,精度为0.005公里。最后一个参数指定缓冲区距离的单位为千米。 执行这个查询后,会返回一个包含缓冲区几何对象的结果集。你可以将结果集中的几何对象保存到Oracle表中,然后使用Oracle Spatial的其他功能进行空间分析。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值