博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SDE ST_Geometry SQL st_intersects查询很慢的解决方法
阅读量:6435 次
发布时间:2019-06-23

本文共 1734 字,大约阅读时间需要 5 分钟。

环境: SDE 10.0 oracle 11.2,客户端 PLSQL 11,oracle 11.2

为了调试方便,以下测试都是把提取出来在PLSQL上做

 


 

需求是已知一个多边形的点坐标,要在一个线图层里,做关系为intersect的空间查询,原来的sql是这样

select LNO  from HSLINE t where sde.st_intersects(t.shape,                         sde.st_geometry(‘polygon ((536001.227128728 3646345.3998618745,535967.7465966925 3646245.5819230564,536081.5112751485 3646231.6260272274,536096.174854475 3646337.021285943,536096.174854475 3646337.021285943,536001.227128728 3646345.3998618745))‘,                                         t.shape.srid)) = 1

 

可是查询很慢,要几分钟,图层数据量才几万,理论上不应该这么慢

 

后来发现是几何对象(st_geometry)造成的,如果把st_geometry放在一个select里,查询速度就正常了

select LNO  from HSLINE t where sde.st_intersects(t.shape,                         (select sde.st_geometry(‘polygon ((536001.227128728 3646345.3998618745,535967.7465966925 3646245.5819230564,536081.5112751485 3646231.6260272274,536096.174854475 3646337.021285943,536096.174854475 3646337.021285943,536001.227128728 3646345.3998618745))‘,                                                 t.shape.srid)                            from HSLINE where rownum=1)) = 1

 

然而这样还有个缺陷,万一表HSLINE一行都没有就会出错,后来同事出了注意,最后做成完美版本

select LNO   HSLINE t where sde.st_intersects(t.shape,                         (select sde.st_geometry(‘polygon ((536001.227128728 3646345.3998618745,535967.7465966925 3646245.5819230564,536081.5112751485 3646231.6260272274,536096.174854475 3646337.021285943,536096.174854475 3646337.021285943,536001.227128728 3646345.3998618745))‘,                                                 t.shape.srid)                             )) = 1

 

dual的解释http://www.cnblogs.com/qiangqiang/archive/2010/10/15/1852229.html

 

最后,这个慢的原因,我觉得是可能每一行做where判断时,都会执行一次st_geometry生成几何对象,如果把它放在一个子select里,就会只做一次子select查询,然后把结果存起来,主表where判断时直接用这个对象

你可能感兴趣的文章
【04-20】httpclient处理302重定向问题
查看>>
OpenGLes2.0 什么是Pbuffer
查看>>
Docker Java+Tomcat 环境搭建
查看>>
uoj#179. 线性规划
查看>>
bzoj 2244 [SDOI2011]拦截导弹(dp+CDQ+树状数组)
查看>>
全局方法
查看>>
DOM 获取、DOM动态创建节点
查看>>
do{...}while(0)的意义和用法
查看>>
【CJOJ】Contest4 - A+B Series
查看>>
Python中四种交换两个变量的值的方法
查看>>
ora-01033:oracle initialization or shutdown in progress 解决方法
查看>>
移动自动化相关名词解释
查看>>
微信开发者工具 快捷键
查看>>
monkey测试===修改adb的默认端口
查看>>
AsyncTask和Handler处理异步消息
查看>>
Scheme 中的 pair 和 list 简述
查看>>
iOS AVAssetExportSession 视频剪切、合并、压缩
查看>>
我收藏的技术知识图(每张都是大图)
查看>>
Spring Boot制作启动图案
查看>>
《Linux内核设计与实现》读书笔记(十一)- 定时器和时间管理
查看>>