空间操作符

一、主要空间操作符

1、SDO_FILTER

SDO_FILTER(geometry1, geometry2, param);

判断两个几何体是否有相交

SELECT c.mkt_id, c.name

FROM cola_markets c

WHERE SDO_FILTER(c.shape,

SDO_GEOMETRY(2003,

NULL,

NULL,

SDO_ELEM_INFO_ARRAY(1, 1003, 3),

SDO_ORDINATE_ARRAY(4, 6, 8, 8))) = 'TRUE';

2、SDO_JOIN

SDO_JOIN(table_name1, column_name1, table_name2, column_name2, params,

preserve_join_order) RETURN SDO_ROWIDSET;

SELECT /*+ ordered */

a.name, b.name

FROM TABLE(SDO_JOIN('COLA_MARKETS',

'SHAPE',

'COLA_MARKETS',

'SHAPE',

'mask=ANYINTERACT')) c,

cola_markets a,

cola_markets b

WHERE c.rowid1 = a.rowid

AND c.rowid2 = b.rowid

ORDER BY a.name;

3、SDO_NN

SDO_NN(geometry1, geometry2, param [, number]);

在指定的距离内,按顺序返回离的最近的。

性能调优参数

sdo_num_res 指定返回离指定点最近的两个市场

sdo_batch_size 指定了一次批量提取多少条记录进行对比

SELECT /*+ INDEX(c cola_spatial_idx) */

c.mkt_id, c.name

FROM cola_markets c

WHERE SDO_NN(c.shape,

sdo_geometry(2001,

NULL,

sdo_point_type(10, 7, NULL),

NULL,

NULL),

'sdo_num_res=2') = 'TRUE';

SELECT /*+ INDEX(c cola_spatial_idx) */

c.mkt_id, c.name

FROM cola_markets c

WHERE SDO_NN(c.shape,

sdo_geometry(2001,

NULL,

sdo_point_type(10, 7, NULL),

NULL,

NULL),

'sdo_batch_size=3') = 'TRUE'

AND c.name < 'cola_d'

AND ROWNUM <= 2;

4、SDO_NN_DISTANCE

SDO_NN_DISTANCE(number);

Number必须与sdo_nn操作符的最后一个参数保持一致。

Sdo_nn操作符是通过计算距离来识别客户的,我们可以通过sdo_nn_distance辅助操作符来获取这些距离。

在使用该操作符时,必须指定一个性能调优参数,sdo_num_res或sdo_batch_size,如果不知道如何设置sdo_batch_size的值,就将其设为0,索引会在内部使用合适的值。

SELECT /*+ INDEX(c cola_spatial_idx) */

c.mkt_id, c.name, SDO_NN_DISTANCE(1) dist

FROM cola_markets c

WHERE SDO_NN(c.shape,

sdo_geometry(2001,

NULL,

sdo_point_type(10, 7, NULL),

NULL,

NULL),

'sdo_num_res=2',

1) = 'TRUE'

ORDER BY dist;

5、SDO_RELATE

SDO_RELATE(geometry1, geometry2, param);

判断两个几何体的关系

SELECT a.gid

FROM polygons a, query_polys B

WHERE B.gid = 1

AND SDO_RELATE(A.Geometry, B.Geometry, 'mask=touch') = 'TRUE'

UNION ALL

SELECT a.gid

FROM polygons a, query_polys B

WHERE B.gid = 1

AND SDO_RELATE(A.Geometry, B.Geometry, 'mask=coveredby') = 'TRUE';

SELECT c.mkt_id, c.name

FROM cola_markets c

WHERE SDO_RELATE(c.shape,

SDO_GEOMETRY(2003,

NULL,

NULL,

SDO_ELEM_INFO_ARRAY(1, 1003, 3),

SDO_ORDINATE_ARRAY(4, 6, 8, 8)),

'mask=anyinteract') = 'TRUE';

6、SDO_WITHIN_DISTANCE

SDO_WITHIN_DISTANCE(geometry1, aGeom, params);

返回与指定点相距指定的距离内的某表的几何对象

SELECT c.name

FROM cola_markets c

WHERE SDO_WITHIN_DISTANCE(c.shape,

SDO_GEOMETRY(2003,

NULL,

NULL,

SDO_ELEM_INFO_ARRAY(1, 1003, 3),

SDO_ORDINATE_ARRAY(4, 6, 8, 8)),

'distance=10') = 'TRUE';

二、关系操作符

语法:

操作符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

11SDO_TOUCH

 

空间函数与操作符的对比

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

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

Oracle_spatial的空间操作符介绍的更多相关文章

  1. SQL连接操作符介绍(循环嵌套, 哈希匹配和合并连接)

    今天我将介绍在SQLServer 中的三种连接操作符类型,分别是:循环嵌套.哈希匹配和合并连接.主要对这三种连接的不同.复杂度用范例的形式一一介绍. 本文中使用了示例数据库AdventureWorks ...

  2. PHP5.3 goto操作符介绍

    goto操作符是PHP5.+后新增功能,用来跳转到程序的另一位置:用法很简单:goto后面带上目标位置的标志,在目标位置上用目标名加冒号标记如下: <?php goto a; echo 'aaa ...

  3. oracle 创建表空间详细介绍

    注意点: 1.如果在PL/SQL 等工具里打开的话,直接修改下面的代码中[斜体加粗部分]执行 2.确保路径存在,比如[D:\oracle\oradata\Oracle9i\]也就是你要保存文件的路径存 ...

  4. 磁盘格式化、磁盘挂载、手动增加swap空间 使用介绍

    第4周第2次课(4月10日) 课程内容: 4.5/4.6 磁盘格式化4.7/4.8 磁盘挂载4.9 手动增加swap空间 4.5/4.6 磁盘格式化 [root@jimmylinux-002 ~]# ...

  5. Oracle_spatial的函数介绍[转]

    Oracle_spatial的函数 一sdo_Geom包的函数: 用于表示两个几何对象的关系(结果为True/False)的函数:RELATE,WITHIN_DISTANCE 验证的函数:VALIDA ...

  6. Oracle_spatial的函数介绍

    Oracle_spatial的函数 一sdo_Geom包的函数: 用于表示两个几何对象的关系(结果为True/False)的函数:RELATE,WITHIN_DISTANCE 验证的函数:VALIDA ...

  7. MySQL中的空间扩展

    目录 19.1. 前言 19.2. OpenGIS几何模型 19.2.1. Geometry类的层次 19.2.2. 类Geometry 19.2.3. 类Point 19.2.4. 类Curve 1 ...

  8. C#基础知识之字符串比较方法:“==”操作符;RefernceEquals;String.Equals方法;String.Compare方法;String.CompareOrdinal方法。

    一.“==”操作符:String.Equals:ReferenceEquals 方法 1.在编程中实际上我们只需要这两种比较,c#中类型也就这两种 (1)值类型的比较:一般我们就是判断两个值类型实例各 ...

  9. Oracle_spatial的常见错误与注意事项

    常见的错误 1.ORA-13226:没有空间索引接口将不被支持 当使用一个空间操作符时,如果没有使用空间索引导致该操作符不能被完成将会返回该错误.这可能会发生在当你使用的列上没有空间索引.或者优化器没 ...

随机推荐

  1. ASP.NET Core (二):入门

    上一篇:ASP.NET Core(一):简介 下一篇:(待续) 英文原版:Getting Started 1. 安装 .NET Core 2. 创建 .NET Core 项目 在命令提示符窗口输入命令 ...

  2. 乱糟unity整理

    当Canvas上的UI元素变化时,会重新生成网格并向GPU发起绘图调用,从而显示UI.划分画布:1.每块画布上的元素都与其他画布的元素相隔离,使用?工具来切分画布?,从而解决ui的批处理问题.2.也可 ...

  3. PowerDesigner 创建表格及导出SQL语句

    PowerDesigner 创建表格及导出SQL语句   目的:提高数据库创建表格效率 测试数据库:orcale 1.新建物理模型. 右键点击workplace,new一个物理模型并指定数据库. 2. ...

  4. Linux下安装SQL Server 2016(连接篇SQL Server on linux)

    连接数据库 (1)设置防火墙 要连接数据库,首先要打开防火墙上1433端口,也就是,增加tcp端口1433到公共区域,并且永久生效. [root@localhost Desktop]# firewal ...

  5. [android] 手机卫士号码归属地查询

    使用小米号码归属地数据库,有两张表data1和data2 先查询data1表,把手机号码截取前7位 select outkey from data1 where id=”前七位手机号” 再查询data ...

  6. Mybatis架构简介

    一.Mybatis与ORM 对象关系映射(即Object Relational Mapping,简称ORM),主要用于关系型数据库和实体之间的映射,主要为了解决对象与关系数据库存在的互不匹配的现象,O ...

  7. 第三十天- 进程 Process模块 空间隔离

    1.进程: 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.在早期面向进程设计的计算机结构中,进程是程序的基本执行实体: ...

  8. js-ES6学习笔记-对象的扩展

    1.ES6允许直接写入变量和函数,作为对象的属性和方法.这种写法用于函数的返回值,将会非常方便.CommonJS模块输出变量,就非常合适使用简洁写法. var ms = {}; function ge ...

  9. SD从零开始47-50, 装运成本基础、控制、结算, 信用/风险管理概述

    [原创] SD从零开始47 装运成本基础 详细的装运成本处理Shipment Cost Processing in Detail 装运成本计算和装运成本结算可用于内向和外向交货: 装运成本记录在一张新 ...

  10. Maven学习(一)概念简述和安装教程

    刚开始由.net转向java,公司的项目中就开始使用maven,感觉他就像nuget一样,但是他又比nuget要强大(毕竟他是项目管理工具). maven概述 在这里,就不背书包了,怎么简单直接怎么来 ...