zoukankan      html  css  js  c++  java
  • Oracle并行添加主键的方法

    环境:Oracle 11.2.0.3
    需求:生产一张表由于前期设计不当,没有主键。现需要添加主键,数据量很大,想并行建立。
     
    1.直接添加,提示ora-3001:未实施的功能;只能单线程建立主键
    SQL> alter table t add constraint pk_t primary key (object_id) using index online parallel 2;
    
    alter table t add constraint pk_t primary key (object_id) using index online parallel 2
    
    ORA-03001: 未实施的功能
    
    SQL> alter table t add constraint pk_t primary key (object_id) using index online;
    
    Table altered
    
    SQL> alter table t drop primary key;
    
    Table altered
    
     
    2.考虑先并行添加惟一性索引,再添加主键
    SQL> create unique index pk_t on t(object_id) parallel 2 online;
    
    Index created
    
    SQL> alter table t add constraint pk_t primary key (object_id);
    
    Table altered
    
    SQL> alter index pk_t noparallel;
    
    Index altered
    
     
    3.对比主键和惟一性索引的区别
    SQL> desc t
    Name           Type          Nullable Default Comments
    -------------- ------------- -------- ------- --------
    OWNER          VARCHAR2(30)  Y                        
    OBJECT_NAME    VARCHAR2(128) Y                        
    SUBOBJECT_NAME VARCHAR2(30)  Y                        
    OBJECT_ID      NUMBER                                 
    DATA_OBJECT_ID NUMBER        Y                        
    OBJECT_TYPE    VARCHAR2(19)  Y                        
    CREATED        DATE          Y                        
    LAST_DDL_TIME  DATE          Y                        
    TIMESTAMP      VARCHAR2(19)  Y                        
    STATUS         VARCHAR2(7)   Y                        
    TEMPORARY      VARCHAR2(1)   Y                        
    GENERATED      VARCHAR2(1)   Y                        
    SECONDARY      VARCHAR2(1)   Y                        
    NAMESPACE      NUMBER        Y                        
    EDITION_NAME   VARCHAR2(30)  Y                        
    
    SQL> alter table t drop primary key;
    
    Table altered
    
    SQL> desc t
    Name           Type          Nullable Default Comments
    -------------- ------------- -------- ------- --------
    OWNER          VARCHAR2(30)  Y                        
    OBJECT_NAME    VARCHAR2(128) Y                        
    SUBOBJECT_NAME VARCHAR2(30)  Y                        
    OBJECT_ID      NUMBER        Y                        
    DATA_OBJECT_ID NUMBER        Y                        
    OBJECT_TYPE    VARCHAR2(19)  Y                        
    CREATED        DATE          Y                        
    LAST_DDL_TIME  DATE          Y                        
    TIMESTAMP      VARCHAR2(19)  Y                        
    STATUS         VARCHAR2(7)   Y                        
    TEMPORARY      VARCHAR2(1)   Y                        
    GENERATED      VARCHAR2(1)   Y                        
    SECONDARY      VARCHAR2(1)   Y                        
    NAMESPACE      NUMBER        Y                        
    EDITION_NAME   VARCHAR2(30)  Y                        
    
    总结:
    对于已有大量数据的表无法并行建立主键,可以先并行建立惟一性索引然后再加上主键。
    主键不能为空,惟一性索引可以为空。
  • 相关阅读:
    通用人工智能离我们还有多远?
    自动化机器上的物联网网关的目的是什么?
    提效降本,您不可不知道的云架构秘诀
    “影子物联网”:日益增长的企业安全盲区
    查找练习 hash——出现过的数字
    查找练习 hash——出现过的数字
    数据结构上机实验之二分查找
    数据结构上机实验之二分查找
    简单字符串比较
    简单字符串比较
  • 原文地址:https://www.cnblogs.com/jyzhao/p/3825134.html
Copyright © 2011-2022 走看看