成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle使用聯機重定義來給表增加新列與分區

數據庫 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就操作完成。

責任編輯:武曉燕 來源: Linux社區
相關推薦

2022-01-11 08:46:56

Oracle 在線重定義數據庫

2010-04-19 14:23:34

Oracle增加表分區

2009-06-24 10:26:41

Oracle約束分區表

2021-01-20 08:07:52

oracle分區單表

2011-03-22 14:49:35

Oracle數據庫重定義表

2010-11-16 11:32:54

ORACLE增加表空間

2010-04-16 13:41:14

Oracle表分區

2011-05-25 14:22:01

oracle偽列偽表

2011-08-01 10:56:51

scott用戶Oracle

2016-12-16 19:13:33

擴展性數據庫

2012-05-07 13:45:45

Oraclen 11g虛擬列數據庫

2011-08-23 10:37:15

Oracle分區表本地索引

2010-04-16 11:00:50

聯機備份Oracle

2009-11-18 16:39:33

Oracle數據庫聯機

2010-04-14 10:32:42

Oracle數據

2012-12-18 15:21:21

UbuntuSwap

2010-04-19 14:57:16

Oracle收縮表分區

2011-08-17 10:49:57

MySQL 5.5多列分區

2010-04-16 15:24:00

Oracle數據

2010-04-22 12:26:10

Oracle數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 999久久久 | 国产清纯白嫩初高生视频在线观看 | 日韩综合一区 | 日韩精品在线视频 | 久久久九九| www亚洲精品 | 亚洲色视频 | 欧洲精品码一区二区三区免费看 | 五月婷婷在线视频 | 365夜爽爽欧美性午夜免费视频 | 成人在线视频网站 | 国产 欧美 日韩 一区 | 国产精品久久久久永久免费观看 | 亚洲第一福利网 | 久久精品视频网站 | 91一区二区 | 国产精品高清在线 | 亚洲人成人一区二区在线观看 | 丝袜美腿一区二区三区动态图 | 亚洲午夜小视频 | 精品美女 | 久久国产精品一区二区 | 91国内精精品久久久久久婷婷 | 成人在线一区二区三区 | a久久| 国产一区二区三区四区在线观看 | 精品久久久久久亚洲国产800 | 欧美片网站免费 | 日韩小视频在线 | 日韩精品一区二区三区高清免费 | 成人免费观看男女羞羞视频 | 国产一区二区久久 | 国产激情一区二区三区 | 亚洲人成人一区二区在线观看 | 久久福利 | av日韩在线播放 | 欧美日韩不卡在线 | 综合久 | 日韩中文字幕网 | 国产视频久久 | 成人小视频在线 |