本篇文章給大家分享的是有關(guān)Oracle中怎么利用聯(lián)機(jī)重定義給表增加新列與分區(qū),小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
成都創(chuàng)新互聯(lián)專注于禪城企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站建設(shè),成都商城網(wǎng)站開(kāi)發(fā)。禪城網(wǎng)站建設(shè)公司,為禪城等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
1.用要執(zhí)行聯(lián)機(jī)重定義操作的用戶登錄數(shù)據(jù)庫(kù)
SQL> conn pm/pm@jypdb Connected.
2.驗(yàn)證表emp_redef是否可以執(zhí)行聯(lián)機(jī)重定義。在這種情況下,可以使用主鍵或偽主鍵來(lái)來(lái)進(jìn)行驗(yàn)證。
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.創(chuàng)建一個(gè)中間表hr.int_emp_redef
SQL> create table hr.int_emp_redef ( employee_id NUMBER(6) not null, first_name VARCHAR2(20), last_name VARCHAR2(25) not null, job_id VARCHAR2(10) not null, department_id NUMBER(4) not null, mgr NUMBER(5), hiredate DATE DEFAULT(sysdate), sal NUMBER(7,2), bonus NUMBER(7,2) DEFAULT(0) ) partition by range(employee_id) ( partition emp200 values less than(200) tablespace users, partition emp400 values less than(400) tablespace users ); Table created
4.開(kāi)始重定義操作
SQL> begin dbms_redefinition.start_redef_table( uname => 'hr', orig_table => 'emp_redef', int_table => 'int_emp_redef', 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', options_flag => DBMS_REDEFINITION.CONS_USE_PK); end; / PL/SQL procedure successfully completed.
5.復(fù)制依賴對(duì)象(自動(dòng)對(duì)表hr.int_emp_redef創(chuàng)建任何觸發(fā)器,索引,物化視圖日志,授權(quán)與約束)
SQL> declare num_errors pls_integer; begin dbms_redefinition.copy_table_dependents( uname => 'hr', orig_table => 'emp_redef', int_table => 'int_emp_redef', copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS, copy_triggers => TRUE, copy_constraints => TRUE, copy_privileges => TRUE, ignore_errors => TRUE, num_errors => num_errors); end; / PL/SQL procedure successfully completed.
注意,在調(diào)用這個(gè)過(guò)程時(shí)ignore_errors參數(shù)需要設(shè)置為T(mén)RUE。原因是中間表創(chuàng)建了主鍵約束,并且當(dāng)執(zhí)行copye_table_dependents過(guò)程來(lái)試圖從原始表復(fù)制主鍵約束與索引時(shí)會(huì)發(fā)生錯(cuò)誤。可以忽略這些錯(cuò)誤,但必須執(zhí)行下一步操作中的查詢來(lái)查看是否還存在其它錯(cuò)誤。
6.查詢dba_redefinition_errors視圖來(lái)查看錯(cuò)誤信息
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.
上面的錯(cuò)誤信息是說(shuō)中間表的last_name與job_id列為not null,而原因表為null,這種錯(cuò)誤可以忽略。
7.同步中間表hr.int_emp_redef
SQL> begin dbms_redefinition.sync_interim_table( uname => 'hr', orig_table => 'emp_redef', int_table => 'int_emp_redef'); end; / PL/SQL procedure successfully completed.
8.完成重定義操作
SQL> begin dbms_redefinition.finish_redef_table( uname => 'hr', orig_table => 'emp_redef', int_table => 'int_emp_redef'); end; / PL/SQL procedure successfully completed.
表hr.emp_redef只會(huì)以排他模式被鎖定很短的時(shí)間來(lái)結(jié)束重定義操作。在操作完成后,表hr.emp_redef將使用hr.int_emp_redef表的所有屬性來(lái)重定義。
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" )
row selected.
可以看到表hr.emp_redef已經(jīng)成功能聯(lián)機(jī)重定義
9.等任何查詢中間表的語(yǔ)句執(zhí)行完成后將其刪除,而且中間表在重定義后其結(jié)構(gòu)就變成了原始表的表結(jié)構(gòu)
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
以上就是Oracle中怎么利用聯(lián)機(jī)重定義給表增加新列與分區(qū),小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)頁(yè)名稱:Oracle中怎么利用聯(lián)機(jī)重定義給表增加新列與分區(qū)
當(dāng)前URL:http://bm7419.com/article20/gijcjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、微信公眾號(hào)、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站維護(hù)、網(wǎng)站建設(shè)、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)