不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

时间:2021-08-27 20:56:12

如果不同版本的ArcMap连接到同一个Oracle数据库上,分别执行"创建镶嵌数据集",它们的行为是一样的吗?

答案是:不一样,会有细微的差别

在本例中,ArcMap的版本分别是10.2.2与10.3,数据库服务器的版本是11.2.0.3,SDE Repository 的版本是10.1 。

  1. 使用10.3版本的ArcMap创建镶嵌数据集 MD1003

    在创建镶嵌数据集之前,创建user_objects的备份表user_objects_b;

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    创建镶嵌数据集,完成后,数据库新增了如下的表、序列、触发器。

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    新增了1个触发器,10个表,7个序列。

    这里有两个知识点,我稍微介绍一下。

    其一,RASTER_LAYER_10以及SDE_RAS_10名称中的10代表什么?

    这个值实际代表的是AMD_MD1003_CAT在sde. RASTER_COLUMNS表中rastercolumn_id字段的值,如下图:

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    其二,R120-R124这几个序列的数字代表什么?

    这个值实际上代表的是上图以AMD开头的5张表在sde.table_registry表中registration_id字段的值,如下图:

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    R120-R124这几个序列是为了给所对应表的OBJECTID字段赋值而存在的。

    那这几个序列是如何定义的呢?我们来看看:

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    注意这里序列的最大值为1028

  2. 使用10.2.2版本的ArcMap创建镶嵌数据集 MD1002

    删除user_objects_b,并重新创建user_objects的备份表user_objects_b;

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    创建镶嵌数据集,完成后,数据库新增了如下的表、序列、触发器。

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    新增了1个触发器,9个表,6个序列。与10.3版本创建镶嵌数据集相比,少了一个以AMD_%_DEF表以及该表所对应的序列。

    同时,由上图可知,AMD_MD1002_CAT的rastercolumn_id值为11,如下图:

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    R开头的序列与AMD开头表的对应关系如下图:

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    序列的定义如下:

    不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为

    注意这里序列的最大值为2147483647,远小于10.3版本创建的序列最大值。

    结论:

    1. 对于"创建镶嵌数据集"这一操作,尽管数据库版本和SDE repository 版本一致,但ArcMap版本的差异仍然会导致不同的递归操作。由此可以引申推测:对于其它操作,不排除因版本不同而导致最终行为不同的情况发生,所以测试与最终生产环节的使用,最好使用同样版本的ArcMap版本。
    2. 使用10.2.2版本创建的镶嵌数据集,其序列最大值为10亿级别,而每次递增值为16,因此可用的值仅为亿级,对于庞大的镶嵌数据集(包含多个数据集,或发生多次删除重入场景)极有可能导致序列被用满而造成添加数据集失败。(另外,由于序列的CACHE值为20,如果经常关闭实例,或经常执行"alter system flush shared_pool"会造成序列产生很多的"洞",而这些"洞"会加速突破序列的最大值限制)

不同版本的ArcMap在Oracle中创建镶嵌数据集的不同行为的更多相关文章

  1. 用ArcMap在PostgreSQL中创建要素类需要执行”create enterprise geodatabase”吗

    问:用Acmap在PostgreSQL中创建要素类需要执行"create enterprise geodatabase"吗? 关于这个问题,是在为新员工做postgresql培训后 ...

  2. 在ArcMap 10.3中创建和编辑数据

    在ArcMap 10.3中创建和编辑数据 .......待补充 新建 创建一个新文件((Points, Polylines, and Polygons/点.线.多边形)

  3. 在oracle中创建空间索引

    Oracle spatial可以方便的存储空间数据,大量的空间数据必需要使用空间索引去查询.在oracle中创建空间索引必需先建立元数据,否则无法创建索引.创建元数据的代码: insert into ...

  4. oracle中创建数据库

    一.在Oracle中创建数据库之前先改一下虚拟机的IP地址,以便访问 2. 3. 3.1 3.2 3.3 3.4 创建完成:输入sqlplus sys/123456 as sysdba测试

  5. Oracle中创建自增字段方法

    oracle没有ORACLE自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现. 下面给大家讲个例子: 1.在Oracle中创建一个表: .创建一个表 ) prim ...

  6. oracle中创建sequence指定起始值

    oracle中创建sequence指定起始值 DECLARE V_Area_Id NUMBER; BEGIN SELECT MAX(T.Area_Id)+10 INTO V_Area_Id FROM ...

  7. Oracle中创建触发器示例及注意事项

    1.oracle 中创建触发器示例 CREATE TABLE "CONCEPT"."FREQUENCYMODIFYLOG" ( "FREQUENCYI ...

  8. 在oracle中创建自动增长字段

    参考http://www.cnblogs.com/jerrmy/archive/2013/03/13/2958352.html http://www.jb51.net/article/43382.ht ...

  9. Oracle中创建千万级大表归纳

    从一月至今,我总共归纳了三种创建千万级大表的方案,它们是: 下面是这三种方案的对比表格: # 名称 地址 主要机制 速度 1 在Oracle中十分钟内创建一张千万级别的表 https://www.cn ...

随机推荐

  1. *POJ1830 高斯消元

    开关问题 Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 8010   Accepted: 3161 Description ...

  2. Android开发学习——开发调试工具-DDMS应用,ADB进程,Logcat

    DDMS --  Dalvik debug monitor service    调试监控服务 对模拟器进行相关配置. ADB进程   Android debug bridge  建立eclipse和 ...

  3. WCF第二天

    消息  : 消息是一个独立的数据单元,它可能由几个部分组成,包括消息正文和消息头.     服务  :  服务是一个构造,它公开一个或多个终结点,其中每个终结点都公开一个或多个服务操作.   终结点 ...

  4. Eclipse小技巧--快速输入System.out.println();(转)

    步骤1:指定“Content Assist”的快捷键,参考:善用 Eclipse 组合键,提高输入效率 步骤2:输入源代码是,先输入sysout,然后输入辅助快捷键:Alt+/,这样就可以自动生成:S ...

  5. PHP 易出问题记录

    PHP foreach引用缺陷 <?php $array = array(1, 2, 3); foreach ($array as &$v) {} foreach ($array as ...

  6. 您为这个网络适配器输入的IP地址xxx&period;xxx&period;xxx&period;xx已经分配给另一个适配器xxx&period;&period;&period;

    您为这个网络适配器输入的IP地址xxx.xxx.xxx.xx已经分配给另一个适配器‘xxx NIC’.... 2008年11月03日 星期一 08:51 问题现象:   在网卡的TCP/IP属性中无法 ...

  7. java socket报文通信(一) socket的建立

    TCP是Transfer Control Protocol的 简称,是一种面向连接的保证可靠传输的协议.通过TCP协议传输,得到的是一个顺序的无差错的数据流.发送方和接收方的成对的两个socket之间 ...

  8. Android&&num;160&semi;DVM

    1.DVM(Dalvik Virtual Machine)概述 是Google公司自己设计用于Android平台的Java虚拟机 支持已经转化为.dex(及Dalvik Excutable)格式的Ja ...

  9. C&num; 填充Excel图表、图例背景色

    填充背景色,一般可以选择多种不同样式来填充背景,包括填充为纯色背景.渐变背景.图片背景或者纹理背景等.下面的内容将分别介绍通过C#来设置Excel中图表背景色.以及图表中的图例背景色的方法. 使用工具 ...

  10. Inside a low budget consumer hardware espionage implant

    The following analysis was performed on a S8 data line locator which replied to the hidden SMS comma ...