SDEforOracle存储机制.docVIP

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SDEforOracle存储机制.doc

SDE研究系列(1):BLOB数据在oracle 地理数据库中的存储方式 ? ? BLOB (binary large object)是数据库中用来存储二进制文件的字段类型.它是几年前Oracle公司实现的替代LONG RAW 方式存储二进制数据的技术。 ? ? BLOB的结构分为3部分:BLOB列( BLOB columns ), LOB 段(LOB segment),LOB索引(LOB index)。BLOB列存储LOB定位器(LOB locator)(36字节)和二进制数据(数据要小于 3,965 字节,并且in-row storage 选项没有被禁用)。 ? ? 注意:ESRI的测试表明使用in-row storage 方式能够达到最高的效率,因此不要禁用in-row storage选项。 ? ? 如果二进制数据大于 3,964 字节,BLOB列中的in-row storage空间不会被分配,LOB定位器指向存储在 LOB段中的二进制数据。因此,启用in-row storage 选项的BLOB列最少空间是36字节(只分配空间给LOB定位器),最大4000字节(存储LOB定位器和 3,964 字节的二进制数据)。 ? ? LOB段被分成很多chunk, chunks必须是oracle数据块大小的整数倍,例如如果oracle数据块的大小是8k,LOB段最小chunk大小是8k。如果存储在LOB段中的数据是5,000 字节,并且假设oracle数据块的大小是8k,那么在这个chunk中有3,192字节的空间空闲。从 LONG RAW 到BLOB的方式转换数据的时候需要更多的存储空间(大概会增长30%)。 ? ? 经验表明,chunk大小设置为8k能够在浪费最少空间的基础上达到最佳I/O的效率。?? ? ? chunk大小设置为16k比chunk大小设置为8k浪费更多的空间。因此为了减少空间的浪费,有二种选择:1)重新创建数据库,把块大小设置为8k。2)在块大小为8k的tablespace上面创建LOB段,并且需要在SGA中分配一个8k的缓冲缓存。 ? ? Chunk的大小为4k或者2k的时候会更节省空间,但会降低I/O的效率。 ? ? LOB索引只有在LOB段的Chunk个数大于12的时候使用,当Chunk个数小于等于12的时候,通过LOB定位器直接指向二进制数据,当Chunk个数大于12的时候LOB定位器指向LOB索引,通过LOB索引访问二进制数据。 ? ? 下面三个图分别是上面提到的三种情况。 图1 ,二进制数据为3000字节 3,964字节 图2 ,二进制数据为81,920字节 3,964字节 但小于12*8k字节 图2 图三,二进制数据为106,496 字节 12*8k字节SDE研究系列(2):设置DBTUNE参数存储BLOB列设置DBTUNE参数存储BLOB列 ? ? DBTUNE表中的存储参数控制着在oracle中如何创建表和索引。其中一些存储参数定义在创建表的时候使用的数据类型。 ? ? ArcSDE的DBTUNE存储参数,例如GEOMETRY_STORAGE, RASTER_STORAGE, and ATTRIBUTE_BINARY定义了在存储ArcSDE数据的时候使用的oracle数据类型。 ? ? 注意从ArcSDE 9.2开始RASTER_BINARY_TYPE参数被RASTER_STORAGE 替代。 ? ?GEOMETRY_STORAGE 控制矢量数据(featureClass)的存储。RASTER_STORAGE 控制栅格数据(raster dataset, raster catalog, or raster attribute)的存储 。ATTRIBUTE_BINARY 控制其他二进制数据的存储(非矢量和栅格数据)。 ? ? 在ArcSDE中使用BLOB列存储数据,DBTUNE关键字设置如下: GEOMETRY_STORAGE SDELOB RASTER_STORAGE BLOB ATTRIBUTE_BINARY BLOB ? ? ESRI建议使用如下设置来存储矢量和栅格数据: 1)总是使用 in-row storage 选项。因为在GIS系统中大多数的要素数据都小于3,964字节。使用in-row storage 选项选项能达到较好的性能。 2)为需要经常读的数据使用缓冲(Cache); 3)如果ArcSDE不经常更新BLOB数据而是经常插入或删除BLOB数据,那么设置 PCT_VERSION 参数为0,告诉oracle在 LOB段上不需要维护老版本的数据。 4)chuck的大小不应该小于8k。测试表明,存储GIS数据,数据块设置为8k是最合适的。 下面是RASTER_S

文档评论(0)

000 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档