Oracle使用联机重定义来给表增加新列与分区

[[195729]]

因为需要将一张上亿我们要记录的表修改为分区表,所以尝试使用联机重定义来给表增加新列与分区的方法来实现,下面是一个测试的例子,操作系统是Oracle Linux 7.1,数据库为12.2.0.1,原始表为emp_redef,该表存储在hr方案中:

  1. SQL> desc hr.emp_redef 
  2. Name          Type         Nullable Default Comments 
  3. ------------- ------------ -------- ------- -------- 
  4. EMPLOYEE_ID   NUMBER(6) 
  5. FIRST_NAME    VARCHAR2(20) Y 
  6. LAST_NAME     VARCHAR2(25) 
  7. JOB_ID        VARCHAR2(10) 
  8. DEPARTMENT_ID NUMBER(4)    Y 

表emp_redef将按以下规则来进行联机重定义:

.增加新列mgr,hiredate,sal与bonus

.新列bonus被初始化为0

.列department_id的值由10开始增加

.表将被重定义为范围分区表,分区键为employee_id。

联机重定义操作如下:

1.用要执行联机重定义操作的用户登录数据库

  1. SQL> conn pm/pm@jypdb 
  2. Connected. 

2.验证表emp_redef是否可以执行联机重定义。在这种情况下,可以使用主键或伪主键来来进行验证。

  1. SQL> exec dbms_redefinition.can_redef_table(uname=>'HR',tname=>'EMP_REDEF',options_flag=>dbms_redefinition.cons_use_pk); 
  2. PL/SQL procedure successfully completed. 

3.创建一个中间表hr.int_emp_redef

  1. SQL> create table hr.int_emp_redef 
  2.     ( 
  3.       employee_id   NUMBER(6) not null
  4.       first_name    VARCHAR2(20), 
  5.       last_name     VARCHAR2(25) not null
  6.       job_id        VARCHAR2(10) not null
  7.       department_id NUMBER(4) not null
  8.       mgr           NUMBER(5), 
  9.       hiredate      DATE DEFAULT(sysdate), 
  10.      sal           NUMBER(7,2), 
  11.      bonus         NUMBER(7,2) DEFAULT(0) 
  12.    ) 
  13.    partition by range(employee_id) 
  14.    ( 
  15.    partition emp200 values less than(200) tablespace users, 
  16.    partition emp400 values less than(400) tablespace users 
  17.    ); 
  18. Table created 

4.开始重定义操作

  1. SQL> begin 
  2.   dbms_redefinition.start_redef_table( 
  3.   uname => 'hr'
  4.   orig_table => 'emp_redef'
  5.   int_table => 'int_emp_redef'
  6.   col_mapping => 'employee_id employee_id, first_name first_name,last_name last_name, job_id job_id, department_id+10 department_id,0 bonus'
  7.   options_flag => DBMS_REDEFINITION.CONS_USE_PK); 
  8.   end
  9.   / 
  10. PL/SQL procedure successfully completed. 

5.复制依赖对象(自动对表hr.int_emp_redef创建任何触发器,索引,物化视图日志,授权与约束)

  1. SQL> declare 
  2.     num_errors pls_integer; 
  3.     begin 
  4.     dbms_redefinition.copy_table_dependents( 
  5.       uname => 'hr'
  6.       orig_table => 'emp_redef'
  7.       int_table => 'int_emp_redef'
  8.       copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS, 
  9.       copy_triggers => TRUE
  10.      copy_constraints => TRUE
  11.      copy_privileges => TRUE
  12.      ignore_errors => TRUE
  13.      num_errors => num_errors); 
  14.    end
  15.    / 
  16.  
  17. PL/SQL procedure successfully completed. 

注意,在调用这个过程时ignore_errors参数需要设置为TRUE。原因是中间表创建了主键约束,并且当执行copye_table_dependents过程来试图从原始表复制主键约束与索引时会发生错误。可以忽略这些错误,但必须执行下一步操作中的查询来查看是否还存在其它错误。

6.查询dba_redefinition_errors视图来查看错误信息

  1. SQL> set long 8000 
  2. SQL> set pages 8000 
  3. SQL> column object_name heading 'object name' format a20 
  4. SQL> column base_table_name heading 'base table name' format a10 
  5. SQL> column ddl_txt heading 'ddl that caused error' format a40 
  6. SQL> select object_name, base_table_name, ddl_txt from dba_redefinition_errors; 
  7.  
  8. object name          base table ddl that caused error 
  9. -------------------- ---------- ---------------------------------------- 
  10. SYS_C0023200         EMP_REDEF  ALTER TABLE "HR"."INT_EMP_REDEF" MODIFY 
  11.                                 ("LAST_NAME" CONSTRAINT "TMP$$_SYS_C0023 
  12.                                 2000" NOT NULL ENABLE NOVALIDATE) 
  13.  
  14. SYS_C0023201         EMP_REDEF  ALTER TABLE "HR"."INT_EMP_REDEF" MODIFY 
  15.                                 ("JOB_ID" CONSTRAINT "TMP$$_SYS_C0023201 
  16.                                 0" NOT NULL ENABLE NOVALIDATE) 
  17.  
  18.  
  19. rows selected. 

上面的错误信息是说中间表的last_name与job_id列为not null,而原因表为null,这种错误可以忽略。

7.同步中间表hr.int_emp_redef

  1. SQL> begin 
  2.     dbms_redefinition.sync_interim_table( 
  3.       uname => 'hr'
  4.       orig_table => 'emp_redef'
  5.       int_table => 'int_emp_redef'); 
  6.     end
  7.     / 
  8. PL/SQL procedure successfully completed. 

8.完成重定义操作

  1. SQL> begin 
  2.   dbms_redefinition.finish_redef_table( 
  3.      uname => 'hr'
  4.      orig_table => 'emp_redef'
  5.      int_table => 'int_emp_redef'); 
  6.     end
  7.     / 
  8. PL/SQL procedure successfully completed. 

表hr.emp_redef只会以排他模式被锁定很短的时间来结束重定义操作。在操作完成后,表hr.emp_redef将使用hr.int_emp_redef表的所有属性来重定义。

  1. SQL> desc hr.emp_redef 
  2. Name          Type         Nullable Default   Comments 
  3. ------------- ------------ -------- --------- -------- 
  4. EMPLOYEE_ID   NUMBER(6) 
  5. FIRST_NAME    VARCHAR2(20) Y 
  6. LAST_NAME     VARCHAR2(25) 
  7. JOB_ID        VARCHAR2(10) 
  8. DEPARTMENT_ID NUMBER(4) 
  9. MGR           NUMBER(5)    Y 
  10. HIREDATE      DATE         Y        (sysdate) 
  11. SAL           NUMBER(7,2)  Y 
  12. BONUS         NUMBER(7,2)  Y        (0) 
  13.  
  14. SQL> select dbms_metadata.get_ddl(object_type =>'TABLE',name =>'EMP_REDEF',schema => 'HR'from dual; 
  15.  
  16. DBMS_METADATA.GET_DDL(OBJECT_TYPE=>'TABLE',NAME=>'EMP_REDEF',SCHEMA=>'HR'
  17. -------------------------------------------------------------------------------- 
  18.  
  19.   CREATE TABLE "HR"."EMP_REDEF" 
  20.    (    "EMPLOYEE_ID" NUMBER(6,0) NOT NULL ENABLE, 
  21.         "FIRST_NAME" VARCHAR2(20), 
  22.         "LAST_NAME" VARCHAR2(25) NOT NULL ENABLE, 
  23.         "JOB_ID" VARCHAR2(10) NOT NULL ENABLE, 
  24.         "DEPARTMENT_ID" NUMBER(4,0) NOT NULL ENABLE, 
  25.         "MGR" NUMBER(5,0), 
  26.         "HIREDATE" DATE DEFAULT (sysdate), 
  27.         "SAL" NUMBER(7,2), 
  28.         "BONUS" NUMBER(7,2) DEFAULT (0), 
  29.          CONSTRAINT "EMP_REDEF_EMP_ID_PK" PRIMARY KEY ("EMPLOYEE_ID"
  30.   USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS 
  31.   STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 
  32.   PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 
  33.   BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT
  34.   TABLESPACE "USERS"  ENABLE 
  35.    ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
  36.   STORAGE( 
  37.   BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT
  38.   TABLESPACE "USERS" 
  39.   PARTITION BY RANGE ("EMPLOYEE_ID"
  40.  (PARTITION "EMP200"  VALUES LESS THAN (200) SEGMENT CREATION IMMEDIATE 
  41.   PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
  42.  NOCOMPRESS LOGGING 
  43.   STORAGE(INITIAL 8388608 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 
  44.   PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 
  45.   BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT
  46.   TABLESPACE "USERS" , 
  47.  PARTITION "EMP400"  VALUES LESS THAN (400) SEGMENT CREATION IMMEDIATE 
  48.   PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
  49.  NOCOMPRESS LOGGING 
  50.   STORAGE(INITIAL 8388608 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 
  51.   PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 
  52.   BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT
  53.   TABLESPACE "USERS" ) 
  1. row selected. 

可以看到表hr.emp_redef已经成功能联机重定义

9.等任何查询中间表的语句执行完成后将其删除,而且中间表在重定义后其结构就变成了原始表的表结构

  1. SQL> desc hr.int_emp_redef 
  2. Name          Type         Nullable Default Comments 
  3. ------------- ------------ -------- ------- -------- 
  4. EMPLOYEE_ID   NUMBER(6)    Y 
  5. FIRST_NAME    VARCHAR2(20) Y 
  6. LAST_NAME     VARCHAR2(25) 
  7. JOB_ID        VARCHAR2(10) 
  8. DEPARTMENT_ID NUMBER(4)    Y 
  9.  
  10. SQL> drop table hr.int_emp_redef purge; 
  11. Table dropped 

到此,联机重定义表hr.emp_redef就操作完成。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/239326.html<

(0)
运维的头像运维
上一篇2025-04-23 08:49
下一篇 2025-04-23 08:50

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注