java oracle spatial_oracle spatial 查询-程序员宅基地

技术标签: java oracle spatial  

Oracle Spatial查询数据包括二个处理过程:

1.只通过索引查询候选项。通过函数SDO_FILTER实现:

SDO_FILTER(geometry1 MDSYS.SDO_GEOMETRY, geometry2 MDSYS.SDO_GEOMETRY, params VARCHAR2)

geometry1:必须是被索引的几何数据

geometry2:不一定是表中的空间字段,也不要求被索引

params:Filter类型

querytype=WINDOW:geometry2不要求来自表

querytype=JOIN:geometry2必须来自表

SELECT name boat_name

FROM mylake t

WHERE feature_id = 12

AND SDO_FILTER(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,

mdsys.sdo_elem_info_array(1,1003,1),

mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),

'querytype=WINDOW') = 'TRUE';

2.再检查每个候选项是否和条件精确匹配。通过函数SDO_RELATE实现:

SDO_RELATE(geometry1 MDSYS.SDO_GEOMETRY, geometry2 MDSYS.SDO_GEOMETRY, params VARCHAR2)

params:masktype类型

DISJOINT — the boundaries and interiors do not intersect

TOUCH — the boundaries intersect but the interiors do not intersect

OVERLAPBDYDISJOINT — the interior of one object intersects the boundary and interior of the other object, but the two boundaries do not intersect. This relationship occurs, for example, when a line originates outside a polygon and ends inside that polygon.

OVERLAPBDYINTERSECT — the boundaries and interiors of the two objects intersect

EQUAL — the two objects have the same boundary and interior

CONTAINS — the interior and boundary of one object is completely contained in the interior of the other object

COVERS — the interior of one object is completely contained in the interior of the other object and their boundaries intersect

INSIDE — the opposite of CONTAINS. A INSIDE B implies B CONTAINS A.

COVEREDBY — the opposite of COVERS. A COVEREDBY B implies B COVERS A.

ON — the interior and boundary of one object is on the boundary of the other object (and the second object covers the first object). This relationship occurs, for example, when a line is on the boundary of a polygon.

ANYINTERACT — the objects are non-disjoint.

// 选择在定义矩形内的所有小船

SELECT name boat_name

FROM mylake t

WHERE feature_id = 12

AND SDO_FILTER(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,

mdsys.sdo_elem_info_array(1,1003,1),

mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),

'querytype=WINDOW') = 'TRUE'

AND SDO_RELATE(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,

mdsys.sdo_elem_info_array(1,1003,1),

mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),

'masktype=INSIDE querytype=WINDOW') = 'TRUE'

// masktype可联合使用

SELECT feature_id id

FROM mylake t

WHERE feature_id = 12

AND SDO_FILTER(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,

mdsys.sdo_elem_info_array(1,1003,1),

mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),

'querytype=WINDOW') = 'TRUE'

AND SDO_RELATE(t.shape, mdsys.sdo_geometry(2003,NULL,NULL,

mdsys.sdo_elem_info_array(1,1003,1),

mdsys.sdo_ordinate_array(2,2, 5,2, 5,5, 2,5, 2,2)),

'masktype=INSIDE+TOUCH querytype=WINDOW') = 'TRUE'

Oracle Spatial 提供的其他查询函数:

Query Description

SDO_NN Nearest neighbor

SDO_SDO_WITHIN_DISTANCE All geometries with a certain distance

Functions Description

SDO_GEOM.SDO_MBR The minimum bounding rectangle for a geometry

SDO_GEOM.SDO_DISTANCE The distance between two geometries

SDO_GEOM.SDO_INTERSECTION Provides the intersection point of two geometries

posted on 2009-05-15 11:39 棋剑小秋 阅读(840) 评论(0)  编辑  收藏 所属分类: 数据库

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_42513601/article/details/114464147

智能推荐

Kubernetes(K8s)从入门到精通_kubernetes 入门到精通.doc-程序员宅基地

文章浏览阅读3.9k次,点赞3次,收藏17次。K8s从入门到精通一、Docker背景和K8s介绍1.1 应用部署方式演变1.2 K8s介绍1.3 K8s组件1.4 K8s概念二、集群环境搭建一、Docker背景和K8s介绍1.1 应用部署方式演变部署方式传统部署虚拟化部署容器化部署概念直接将应用部署在物理机上在一台物理机上运行多个虚拟机,每个虚拟机是一个独立的环境与虚拟机类似,但是共享了操作系统优点简单应用环境不会相互影响,有一定的安全性保证每个容器有自己的文件系统、CPU、内存等缺点很难合理分配_kubernetes 入门到精通.doc

MSF后渗透模块Meterpreter-程序员宅基地

文章浏览阅读4k次,点赞4次,收藏40次。目录后门persistencemetsvc图形界面getgui信息收集判断目标是不是虚拟机arp主机发现nmap主机发现dumplink-最近访问的文件记录enum_applications-安装的软件收集补丁信息键盘记录抓包浏览器系统口令kiwi内网渗透开启远程桌面添加路由445端口扫描哈希值传递攻击-psexecPortfwd端口转发域信息收集密码喷射令牌窃取痕迹清理后门由于 Meterpreter是仅仅驻留在内存中的 Shellcode,一旦目标主机重启,将失去这台机器的控制权,如果管理员将利用的_msf后渗透模块

python+tensorflow2.x+opencv搭建真实场景下的手写数字识别_使用python和opencv和tensorflow实现手写数字识别-程序员宅基地

文章浏览阅读2.1k次,点赞15次,收藏50次。python+tensorflow2.x+opencv搭建真实场景下的手写数字识别初步成果第一步训练手写数字模型引入需要的库文件读取数据看一下数据什么样数据归一化搭建模型固化模型训练模型看一下我们的训练成果用模型预测一个数据保存模型opencv计算机视觉部分先引入必须的库文件必要的全局变量写一个函数用来查看图片读取图片改变图片大小灰度化处理边缘检测闭运算在图片外围加上边框获取边框最后一步,识别加标..._使用python和opencv和tensorflow实现手写数字识别

shell脚本查找指定字符串_shell字符串查找-程序员宅基地

文章浏览阅读7.2k次。name1="#${location_name}loc_start" #name1为你想要查找的字符串a=$(cat -n ${nginx_path}/nginx.conf|grep "$name1"|cut -f1) #a为查找到的行号_shell字符串查找

LINUX学习-用C语言实现FTP项目_linux 下c语言开发ftp下载工具-程序员宅基地

文章浏览阅读3.2k次,点赞3次,收藏23次。FTP(File Transfer Protocol,文件传输协议) 是 TCP/IP 协议组中的协议之一。FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客户端。其中FTP服务器用来存储文件,用户可以使用FTP客户端通过FTP协议访问位于FTP服务器上的资源。在开发网站的时候,通常利用FTP协议把网页或程序传到Web服务器上。此外,由于FTP传输效率非常高,在网络上传输大的文件时,..._linux 下c语言开发ftp下载工具

Java集合 高频面试题_java 集合面试题-程序员宅基地

文章浏览阅读1.5k次,点赞3次,收藏17次。之前以为面经只是死记硬背的东西,后来发现记住了它们,对自己对知识的理解确实有帮助,难怪语文的文章老是要求背背背。前言这次的面经整理分为以下几个部分,希望对大家的工作有帮助。内容链接地址Java 基础Java 集合Java 多线程Java 虚拟机计算机网络数据结构和算法数据库JavaWeb设计模式Spring、MyBatis目录:前言1 Java 集合概论2 如何选用集合3 扩容机制3.1 Array._java 集合面试题

随便推点

程序员如何写自己的第一篇博客_java程序员的博客开始写什么-程序员宅基地

文章浏览阅读4.9k次,点赞15次,收藏3次。程序员写第一篇博客的心态这个是我的第一篇博客,从事java开发也将近两年的时间了,平时不管遇到大大小小的问题,只要自己解决不了的都是网上百度解决的。所以对于我们初级程序员来说,这个阶段其实就是不断百度和拷贝粘贴代码的阶段,但是现在感觉自己到了一个瓶颈期了,每天从事的内容没有什么难度,遇到的bug也大多数是业务层面上,去看下招聘网站要求的东西是真的多,有可能是现在互联网寒冬的原因吧,有大批优秀的程..._java程序员的博客开始写什么

c语言volatile原理,C++ 中 volatile 的使用-程序员宅基地

文章浏览阅读969次。简单地说就是防止编译器对代码进行优化.好比以下程序:XBYTE[2]=0x55;XBYTE[2]=0x56;XBYTE[2]=0x57;XBYTE[2]=0x58;对外部硬件而言,上述四条语句分别表示不一样的操做,会产生四种不一样的动做,可是编译器却会对上述四条语句进行优化,认为只有XBYTE[2]=0x58(即忽略前三条语句,只产生一条机器代码)。若是键入volatile,则编译器会逐一的进行编..._c++ volatile 布尔变量 赋值

通过蓝牙芯片(HC-05)与手机 APP 通信_hc-05与手机app通信代码-程序员宅基地

文章浏览阅读769次。项目场景:提示:这里简述项目相关背景:例如:项目场景:示例:通过蓝牙芯片(HC-05)与手机 APP 通信,每隔 5s 传输一批传感器数据(不是很大)问题描述提示:这里描述项目中遇到的问题:例如:数据传输过程中数据不时出现丢失的情况,偶尔会丢失一部分数据APP 中接收数据代码:@Override public void run() { bytes = mmInStream.read(buffer); mHandler.obtainMessage(READ_DATA, bytes, _hc-05与手机app通信代码

iOS10 XCode8 证书问题Signing解决方法_signing & capabilities ->signing 不显示证书-程序员宅基地

文章浏览阅读2.7w次。中秋节项目要发布,临时在家里电脑打包,发现证书一直识别失败。仔细看了Xcode的配置。尼玛Build Setting里原有的证书设置 居然Deprecated了。然后工程一直打包失败,Target - General 里各种红色感叹号,识别不出匹配的证书。折腾了半天发现用下面的方法,10秒钟完美解决:Target - General - 勾选 X_signing & capabilities ->signing 不显示证书

vscode 无法打开源文件c/c++(1696)_无法打开源文件 "can_msgs/frame.h"c/c++(1696)-程序员宅基地

文章浏览阅读2.1w次,点赞9次,收藏31次。前言学习用VScode远程连接Ubuntu编写C代码时,出现无法打开无法打开源文件c\c++(1696)的红色报错寻找解决办法百度了一下,看到有“在c_cpp_properties.json,添加include路径”的做法,详见这里然后发现我Ubuntu上的include里没有stdio.h源文件,才发现我犯了个低级错误——没安装gcc和g++。之前用apt 命令没有成功安装gcc和g++,出现了依赖错误。在博客上找到了解决办法:使用aptitude包依赖管理工具代替apt来处理,ap_无法打开源文件 "can_msgs/frame.h"c/c++(1696)

js对象转换_[{name1:'',name:2:''}] 怎么改成一样的 js-程序员宅基地

文章浏览阅读280次。_[{name1:'',name:2:''}] 怎么改成一样的 js

推荐文章

热门文章

相关标签