码迷,mamicode.com
首页 > 其他好文 > 详细

ST_Geometry效率的测试与分析

时间:2015-10-16 08:44:24      阅读:305      评论:0      收藏:0      [点我收藏+]

标签:

测试环境

数据库:Oracle11g R1(11.1.0.6) 64Bit

中间件:ArcSDE10 (64Bit)

数据情况:点数据(point,231772条记录),面数据(poly,12条记录)如下图所示

技术分享

1:ST_Geometry操作符的选择

测试内容

测试面状要素所包含的点状要素的数量以及内容

测试结果

我使用两种方式分别进行相关测试,一种是利用面包含点的方式(Contains),一种是利用点在面内部的方式(within),我们看看这两种方式有什么区别

第一种方式:

  1. SQL> select sde.st_astext(point.shape) from point,poly where  
  2. sde.st_contains(poly.shape,point.shape)=1;  

 

技术分享

查看执行计划可以看出,使用ST_Contains走的全表扫描(Table Access Full)

第二种方式:

  1. SQL> select sde.st_astext(point.shape) from point,poly where sde.st_within(point  
  2. .shape,poly.shape)=1;  

 

技术分享

从执行计划可以看出,使用ST_Within走的是索引。

测试结果分析

从上面的测试结果我们可以看出(有可能是某个点刚好在面的边界上,致使Contain和within的查询数量不同),使用不同的查询方式,得出结果的时间却差距很大,这是为什么呢?

在ST_Geometry操作符的使用过程中,有些操作符是走空间索引的如ST_Within函数,但是有些操作符是不走空间索引的如ST_Contains函数,那么我们在使用ST函数的过程中一定要尽量使用走空间索引的操作符,那么那些操作符走空间索引呢?

技术分享

从上面我们可以看到列举出来的操作符是走空间索引的,没有列出了的是不走空间索引的,该走全表扫描。声明一下:各个数据库可能操作符不一样。

2:ST_Geometry操作符的所传递的对象位置顺序

测试内容

测试面状要素所包含的点状要素的数量以及内容

测试结果

我们使用两种方式进行测试。这次我们都用ST_INTERSECTS进行测试,从上面我们可以看到这个操作符是走空间索引的。

第一种方式

  1. SQL> select sde.st_astext(point.shape) from point,poly where  
  2. sde.st_intersects(poly.shape,point.shape)=1;  

 

技术分享

第二种方式

  1. SQL> select sde.st_astext(point.shape) from point,poly where  
  2. sde.st_intersects(point.shape,poly.shape)=1;  

 

技术分享

测试分析

从上面的示例可以看出,调换了一下传入参数的位置,得到结果的时间差别仍然很大。

由第一种方法可以看到,使用时间与示例一的Contains时间大致一致,走的也应该是全表扫描,第一种方式是全表扫描每一个点,然后将该点与面进行比较获得结果,第二种方式是全表扫描每一个面,然后将该面与点进行比较得到结果,面与点的比较走的是点的索引,可见第二种方式效率更高。

技术分享

如果用户感觉这个比较麻烦不好记忆,用户只需要记住将数据量小的放在函数传入值的后面即可。即ST_INTERSACTS(数据量大,数据量小)。

3:ST_Geometry操作符与属性条件位置顺序

测试内容

测试面状要素所包含的点状要素的数量以及内容,但是可能包含以下属性过滤条件。

测试结果

技术分享

技术分享

第一种方法

  1. Select sde.st_astext(point.shape) from point,poly  
  2. where sde.st_intersects(point.shape,poly.shape)=1 and point.objectid<100000  

 

第二种方法

  1. select sde.st_astext(point.shape) from point,poly where  
  2. point.objectid<100000 and sde.st_intersects(point.shape,poly.shape)=1  

 

不管是第一种方法还是第二种方法执行时间基本差不多,执行计划也是一样的,所以说,当针对查询条件有属性过滤条件的,是先走的属性条件,再走的空间条件,所以说针对哪个属性过滤需要注意的是建立相关的属性索引。

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

ST_Geometry效率的测试与分析

标签:

原文地址:http://www.cnblogs.com/love540376/p/4884215.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!