本篇內(nèi)容介紹了“Oracle12.2怎么用對(duì)象數(shù)據(jù)類(lèi)型來(lái)重定義表”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)公司主營(yíng)龍海網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP軟件開(kāi)發(fā),龍海h5小程序制作搭建,龍海網(wǎng)站營(yíng)銷(xiāo)推廣歡迎龍海等地區(qū)企業(yè)咨詢(xún)
Oracle 12.2使用對(duì)象數(shù)據(jù)類(lèi)型來(lái)重定義表,下面的例子將重定義表將列改變?yōu)閷?duì)象屬性,原始表為customer,定義如下:
SQL> create table jy.customer( 2 cid number not null, 3 name varchar2(30), 4 street varchar2(100), 5 city varchar2(30), 6 state varchar2(2), 7 zip number(5) 8 ); Table created SQL> alter table jy.customer add constraint customer_pk primary key(cid); Table altered
創(chuàng)建新的對(duì)象類(lèi)型
SQL> create type jy.addr_t as object 2 ( 3 street varchar2(100), 4 city varchar2(30), 5 state varchar2(2), 6 zip number(5,0) 7 ); 8 9 / Type created
聯(lián)機(jī)重定義操作如下:
1.用要執(zhí)行聯(lián)機(jī)重定義操作的用戶(hù)登錄數(shù)據(jù)庫(kù)
SQL> conn jy/jy@jypdb Connected.
2.驗(yàn)證表是否可以執(zhí)行聯(lián)機(jī)重定義,可以使用主鍵或偽主鍵來(lái)執(zhí)行驗(yàn)證操作。
SQL> begin 2 dbms_redefinition.can_redef_table( 3 uname => 'jy', 4 tname =>'customer', 5 options_flag => DBMS_REDEFINITION.CONS_USE_PK); 6 end; 7 / PL/SQL procedure successfully completed
3.創(chuàng)建中間表jy.int_customer
SQL> create table jy.int_customer 2 ( 3 cid number, 4 name varchar2(30), 5 addr addr_t 6 ); Table created
4.因?yàn)閏ustomer是一個(gè)非常大的表,為了讓下一步操作啟用并行執(zhí)行以下語(yǔ)句:
SQL> alter session force parallel dml parallel 4; Session altered SQL> alter session force parallel query parallel 4; Session altered
5.使用主鍵來(lái)執(zhí)行重定義操作
SQL> begin 2 dbms_redefinition.start_redef_table( 3 uname => 'jy', 4 orig_table => 'customer', 5 int_table => 'int_customer', 6 col_mapping => 'cid cid, name name, 7 addr_t(street, city, state, zip) addr'); 8 end; 9 / PL/SQL procedure successfully completed
6.復(fù)制依賴(lài)對(duì)象
SQL> declare 2 num_errors pls_integer; 3 begin 4 dbms_redefinition.copy_table_dependents( 5 uname => 'jy', 6 orig_table => 'customer', 7 int_table => 'int_customer', 8 copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS, 9 copy_triggers => TRUE, 10 copy_constraints => TRUE, 11 copy_privileges => TRUE, 12 ignore_errors => FALSE, 13 num_errors => num_errors, 14 copy_statistics => TRUE); 15 end; 16 / PL/SQL procedure successfully completed
7.可選操作同步中間表
SQL> begin 2 dbms_redefinition.sync_interim_table( 3 uname => 'jy', 4 orig_table => 'customer', 5 int_table => 'int_customer'); 6 end; 7 / PL/SQL procedure successfully completed
8.完成重定義操作
SQL> begin 2 dbms_redefinition.finish_redef_table( 3 uname => 'jy', 4 orig_table => 'customer', 5 int_table => 'int_customer'); 6 end; 7 / PL/SQL procedure successfully completed
SQL> select dbms_metadata.get_ddl(object_type =>'TABLE',name =>'CUSTOMER',schema => 'JY') from dual; DBMS_METADATA.GET_DDL(OBJECT_TYPE=>'TABLE',NAME=>'CUSTOMER',SCHEMA=>'JY') -------------------------------------------------------------------------------- CREATE TABLE "JY"."CUSTOMER" ( "CID" NUMBER NOT NULL ENABLE, "NAME" VARCHAR2(30), "ADDR" "JY"."ADDR_T" , CONSTRAINT "CUSTOMER_PK" PRIMARY KEY ("CID") 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 "TEST" ENABLE ) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING 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 "TEST" 1 row selected.
可以看到表jy.customer已經(jīng)成功能聯(lián)機(jī)重定義
9.等待任何查詢(xún)中間表的語(yǔ)句執(zhí)行完成后將其刪除
SQL> desc jy.customer Name Type Nullable Default Comments ---- ------------ -------- ------- -------- CID NUMBER NAME VARCHAR2(30) Y ADDR ADDR_T Y SQL> drop table jy.customer purge; Table dropped
到此重定義操作就完成了。
“Oracle12.2怎么用對(duì)象數(shù)據(jù)類(lèi)型來(lái)重定義表”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!