zoukankan      html  css  js  c++  java
  • ST_Geometry效率的测试与分析

    测试环境

    数据库: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  

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

     

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

  • 相关阅读:
    codevs 1115 开心的金明
    POJ 1125 Stockbroker Grapevine
    POJ 2421 constructing roads
    codevs 1390 回文平方数 USACO
    codevs 1131 统计单词数 2011年NOIP全国联赛普及组
    codevs 1313 质因数分解
    洛谷 绕钉子的长绳子
    洛谷 P1276 校门外的树(增强版)
    codevs 2627 村村通
    codevs 1191 数轴染色
  • 原文地址:https://www.cnblogs.com/telwanggs/p/4884215.html
Copyright © 2011-2022 走看看