Oracle使用聯機重定義來給表增加新列與分割槽
因為需要將一張上億我們要記錄的表修改為分割槽表,所以嘗試使用聯機重定義來給表增加新列與分割槽的方法來實現,下面是一個測試的例子,作業系統是Oracle Linux 7.1,資料庫為12.2.0.1,原始表為emp_redef,該表儲存在hr方案中:
SQL> desc hr.emp_redef Name Type Nullable Default Comments ------------- ------------ -------- ------- -------- EMPLOYEE_ID NUMBER(6) FIRST_NAME VARCHAR2(20) Y LAST_NAME VARCHAR2(25) JOB_ID VARCHAR2(10) DEPARTMENT_ID NUMBER(4) Y
表emp_redef將按以下規則來進行聯機重定義:
.增加新列mgr,hiredate,sal與bonus
.新列bonus被初始化為0
.列department_id的值由10開始增加
.表將被重定義為範圍分割槽表,分割槽鍵為employee_id。
聯機重定義操作如下:
1.用要執行聯機重定義操作的使用者登入資料庫
SQL> conn pm/pm@jypdb Connected.
2.驗證表emp_redef是否可以執行聯機重定義。在這種情況下,可以使用主鍵或偽主鍵來來進行驗證。
SQL> exec dbms_redefinition.can_redef_table(uname=>'HR',tname=>'EMP_REDEF',options_flag=>dbms_redefinition.cons_use_pk); PL/SQL procedure successfully completed.
3.建立一箇中間表hr.int_emp_redef
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 ); Table created
4.開始重定義操作
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 / PL/SQL procedure successfully completed.
5.複製依賴物件(自動對錶hr.int_emp_redef建立任何觸發器,索引,物化檢視日誌,授權與約束)
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 / PL/SQL procedure successfully completed.
注意,在呼叫這個過程時ignore_errors引數需要設定為TRUE。原因是中間表建立了主鍵約束,並且當執行copye_table_dependents過程來試圖從原始表複製主鍵約束與索引時會發生錯誤。可以忽略這些錯誤,但必須執行下一步操作中的查詢來檢視是否還存在其它錯誤。
6.查詢dba_redefinition_errors檢視來檢視錯誤資訊
SQL> set long 8000 SQL> set pages 8000 SQL> column object_name heading 'object name' format a20 SQL> column base_table_name heading 'base table name' format a10 SQL> column ddl_txt heading 'ddl that caused error' format a40 SQL> select object_name, base_table_name, ddl_txt from dba_redefinition_errors; object name base table ddl that caused error -------------------- ---------- ---------------------------------------- SYS_C0023200 EMP_REDEF ALTER TABLE "HR"."INT_EMP_REDEF" MODIFY ("LAST_NAME" CONSTRAINT "TMP$$_SYS_C0023 2000" NOT NULL ENABLE NOVALIDATE) SYS_C0023201 EMP_REDEF ALTER TABLE "HR"."INT_EMP_REDEF" MODIFY ("JOB_ID" CONSTRAINT "TMP$$_SYS_C0023201 0" NOT NULL ENABLE NOVALIDATE) 2 rows selected.
上面的錯誤資訊是說中間表的last_name與job_id列為not null,而原因表為null,這種錯誤可以忽略。
7.同步中間表hr.int_emp_redef
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 / PL/SQL procedure successfully completed.
8.完成重定義操作
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 / PL/SQL procedure successfully completed.
表hr.emp_redef只會以排他模式被鎖定很短的時間來結束重定義操作。在操作完成後,表hr.emp_redef將使用hr.int_emp_redef表的所有屬性來重定義。
SQL> desc hr.emp_redef Name Type Nullable Default Comments ------------- ------------ -------- --------- -------- EMPLOYEE_ID NUMBER(6) FIRST_NAME VARCHAR2(20) Y LAST_NAME VARCHAR2(25) JOB_ID VARCHAR2(10) DEPARTMENT_ID NUMBER(4) MGR NUMBER(5) Y HIREDATE DATE Y (sysdate) SAL NUMBER(7,2) Y BONUS NUMBER(7,2) Y (0)
SQL> select dbms_metadata.get_ddl(object_type =>'TABLE',name =>'EMP_REDEF',schema => 'HR') from dual; DBMS_METADATA.GET_DDL(OBJECT_TYPE=>'TABLE',NAME=>'EMP_REDEF',SCHEMA=>'HR') -------------------------------------------------------------------------------- CREATE TABLE "HR"."EMP_REDEF" ( "EMPLOYEE_ID" NUMBER(6,0) NOT NULL ENABLE, "FIRST_NAME" VARCHAR2(20), "LAST_NAME" VARCHAR2(25) NOT NULL ENABLE, "JOB_ID" VARCHAR2(10) NOT NULL ENABLE, "DEPARTMENT_ID" NUMBER(4,0) NOT NULL ENABLE, "MGR" NUMBER(5,0), "HIREDATE" DATE DEFAULT (sysdate), "SAL" NUMBER(7,2), "BONUS" NUMBER(7,2) DEFAULT (0), CONSTRAINT "EMP_REDEF_EMP_ID_PK" PRIMARY KEY ("EMPLOYEE_ID") USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "USERS" ENABLE ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 STORAGE( BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "USERS" PARTITION BY RANGE ("EMPLOYEE_ID") (PARTITION "EMP200" VALUES LESS THAN (200) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 8388608 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "USERS" , PARTITION "EMP400" VALUES LESS THAN (400) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 8388608 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "USERS" ) 1 row selected.
可以看到表hr.emp_redef已經成功能聯機重定義
9.等任何查詢中間表的語句執行完成後將其刪除,而且中間表在重定義後其結構就變成了原始表的表結構
SQL> desc hr.int_emp_redef Name Type Nullable Default Comments ------------- ------------ -------- ------- -------- EMPLOYEE_ID NUMBER(6) Y FIRST_NAME VARCHAR2(20) Y LAST_NAME VARCHAR2(25) JOB_ID VARCHAR2(10) DEPARTMENT_ID NUMBER(4) Y SQL> drop table hr.int_emp_redef purge; Table dropped
到此,聯機重定義表hr.emp_redef就操作完成。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26015009/viewspace-2141105/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 使用ORACLE線上重定義將普通表改為分割槽表Oracle
- ORACLE 線上重新定義表分割槽表重定義為普通表。Oracle
- Oracle分割槽表基礎運維-07增加分割槽(3列表分割槽)Oracle運維
- oracle分割槽表線上重定義欄位not null問題OracleNull
- ORACLE 普通錶轉換成分割槽表(線上重定義)Oracle
- 使用DBMS_REDEFINITION線上重定義表普通表為分割槽表
- ORACLE 普通錶轉換成分割槽表(線上重定義)(zt)Oracle
- 使用線上重定義方法改造普通表為分割槽表實戰
- 【Oracle】利用線上重定義的方式改變普通表為分割槽表Oracle
- 普通錶轉換分割槽表-線上重定義
- Oracle 12.2 聯機重定義使用VPD策略的表並不修改表的任何列Oracle
- 分割槽表和dbms_redefinition包線上重定義表
- 線上重定義分割槽表和NOLOGGING APPEND分割槽表對比APP
- Oracle 12.2 聯機重定義多個分割槽並將其移動到不同的表空間中Oracle
- 線上重定義 ?普通錶轉換成分割槽表
- 海量資料處理_表分割槽(線上重定義)
- Oracle分割槽表基礎運維-07增加分割槽(2 HASH分割槽)Oracle運維
- Oracle的使用者表自動增加分割槽Oracle
- Oracle分割槽表基礎運維-07增加分割槽(1範圍分割槽)Oracle運維
- sql server針對表增加新的分割槽SQLServer
- Oracle分割槽表基礎運維-04列表分割槽Oracle運維
- Oracle定時刪除、增加表分割槽(TOAD,PL/SQL)(轉)OracleSQL
- Oracle 12.2 聯機重定義使用VPD策略的表並修改表的列名Oracle
- 10g線上重定義新特性——對單獨的分割槽進行線上重定義
- oracle實用sql(14)--查詢分割槽表的分割槽列和子分割槽列OracleSQL
- Oracle分割槽表的使用Oracle
- 【實驗】【PARTITION】RANGE分割槽表增加分割槽
- [引用分割槽表]Oracle 11g新特性之引用分割槽表Oracle
- Oracle 12.2使用手動建立與註冊依賴物件來執行聯機重定義Oracle物件
- oracle分割槽表和分割槽表exchangeOracle
- 全面學習分割槽表及分割槽索引(8)--增加和收縮表分割槽索引
- 指令碼:線上重定義,從普通表到分割槽表,redefinition_table.sh指令碼
- Oracle帶區域性分割槽索引的分割槽表刪除舊分割槽新增新分割槽Oracle索引
- Oracle分割槽表基礎運維-07增加分割槽(4 RANGE_HASH)Oracle運維
- Oracle分割槽表基礎運維-07增加分割槽(5RANGE_LIST)Oracle運維
- Oracle分割槽表基礎運維-07增加分割槽(6RANGE_RANGE)Oracle運維
- Oracle中分割槽表的使用Oracle
- oracle 線上重新定義,普通表改變分割槽表,分割槽表可以更改型別、分割槽欄位等Oracle型別