测试环境

数据库: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效率的测试与分析的更多相关文章

  1. 读《实战GUI自动化测试》之:第三步,如何提高测试结果分析的效率

    转自:http://www.ibm.com/developerworks/cn/rational/r-cn-guiautotesting3/ 所谓自动化测试,就是“自动化”+“测试”.自动化本身显然不 ...

  2. LoadRunner测试结果分析03 转载至zhangzhe的新浪博客

    LoadRunner测试结果分析之我见 前面分析的Web Resource(网络资源)的测试情况,其主要关注的是服务器性能,而系统本身和环境都有可能存在问题,页面诊断(Web Page Diagnos ...

  3. LoadRunner测试结果分析02 转载至zhangzhe的新浪博客

    LoadRunner测试结果分析之我见 上述测试过程的重点在于事务,而LoadRunner生成的测试结果图并不局限于事务上,其中还有是关于Vusers.Errors.Web Resources.Web ...

  4. LoadRunner测试结果分析01 转载至zhangzhe的新浪博客

    LoadRunner测试结果分析之我见 LoadRunner生成测试结果并不代表着这次测试结果的结束,相反,这次测试结果的重头戏才刚刚开始.如何对测试结果进行分析,关系着这次测试的成功与否.网上关于L ...

  5. Monkey测试3——Monkey测试结果分析

    Monkey测试结果分析 一. 初步分析方法: Monkey测试出现错误后,一般的差错步骤为以下几步: 1. 找到是monkey里面的哪个地方出错 2. 查看Monkey里面出错前的一些事件动作,并手 ...

  6. http_load安装与测试参数分析 - 追求自由自在的编程 - ITeye技术网站

    http_load安装与测试参数分析 - 追求自由自在的编程 - ITeye技术网站 http_load -p 50 -s 120 urls

  7. loadrunner测试结果分析

    LR性能测试结果样例分析 测试结果分析 LoadRunner性能测试结果分析是个复杂的过程,通常可以从结果摘要.并发数.平均事务响应时间.每秒点击数.业务成功率.系统资源.网页细分图.Web服务器资源 ...

  8. web端常见安全漏洞测试结果分析-- appscan

    基于appscan测试结果分析: 一.XSS跨站脚本 指的是攻击者往Web页面里插入恶意html代码,通常是JavaScript编写的恶意代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被 ...

  9. MinHook测试与分析(x86下 E8,E9,EB,CALL指令测试,且逆推测试微软热补丁)

    依稀记得第一次接触Hook的概念是在周伟民先生的书中-><<多任务下的数据结构与算法>>,当时觉得Hook的本质就是拦截,就算到现在也是如此认为. 本篇文章是在x86下测 ...

随机推荐

  1. Find the Top 10 commands in your linux box!

    history | awk '{print $2;}' | grep -v '^./' | sort -d | uniq -c | sort -nr | head -n 10 grep,  '-v' ...

  2. mybatis教程4(动态SQL)

    动态SQL语句 MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句的痛苦.例如拼接时要确保不能忘记添加必要的空 ...

  3. MySQL中的事务及读写锁实现并发访问控制

    一.并发控制中锁的概念 锁是并发控制中最核心的概念之一,在MySQL中的锁分两大类,一种是读锁,一种是写锁,读锁也可以称为共享锁(shared lock),写锁也通常称为排它锁(exclusive l ...

  4. 深入浅出 JVM GC(1)

    # 前言 初级 Java 程序员步入中级程序员的有一个无法绕过的阶段------GC(Garbage Collection).作为 Java 程序员,说实话,很幸福,不用像 C 程序员那样,时刻关心着 ...

  5. base64编码的作用【转】

    转自:https://www.zhihu.com/question/36306744/answer/71626823 X.509公钥证书也好,电子邮件数据也好,经常要用到Base64编码,那么为什么要 ...

  6. RBAC 权限设计(转载)

    来源 :https://blog.csdn.net/rocher88/article/details/43190743 这是我在网上找的一些设计比较好的RBAC权限管理 不知道,像新浪.搜狐.网易.百 ...

  7. [PHP] 算法-二叉树的子结构判断的PHP实现

    输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 1.子树的意思是包含了一个节点,就得包含这个节点下的所有节点,两棵树同时到底 2.子结构可以是A树的任意一部 ...

  8. cocoapods使用-库托管到svn或者github

    下拉svn库(自定义库或者第三方库)到工程中:   1. 若未安装,请安装cocoapods:    http://www.cnblogs.com/sunjianfei/p/6089231.html ...

  9. Java基础——JSON

    一.JSON定义 在百度百科中的解释:JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于JavaScript的一个子集. JSON采用完全独立于语言的 ...

  10. 浏览器与Tomcat交互

    浏览器与Tomcat交互 Web开发者都知道在Tomcat下部署应用后启动Tomcat即可通过浏览器与Tomcat建立连接. 那么二者之间的连接建立过程是怎么样的呢?(在此,我们不具体讲述关于网络底层 ...