Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> डेटाबेस

DBMS_REDEFINITION पैकेज का उपयोग करके Oracle ऑनलाइन तालिका विभाजन

Oracle® 10g से शुरू करके, आप DBMS_REDEFINITION पैकेज का उपयोग करके बिना किसी एप्लिकेशन डाउनटाइम के तालिकाओं को ऑनलाइन विभाजित कर सकते हैं।

DBMS_REDEFINITION का उपयोग करके गैर-विभाजन तालिका को विभाजन तालिका में बदलने के लिए निम्न चरणों का उपयोग करें। यह उदाहरण गैर-विभाजन तालिका, TABLEA, को एक श्रेणी अंतराल विभाजन तालिका में बदलता है।

चरण 1:विभाजन तालिका का बैकअप लें

तालिका, TABLEA का पूर्ण निर्यात बैकअप बनाने के लिए निम्न कोड चलाएँ।

expdp  \"/ as sysdba\" directory=EXPDP_DIR dumpfile=tableA_UNPAR.dmp logfile=tableA_UNPAR.log TABLES=TEST.TABLEA

expdp  \"/ as sysdba\"  directory=EXPDP_DIR dumpfile=tableA_metaunpar.dmp logfile=tableA_metaunpar.log TABLES=TEST.TABLEA content=metadata_only

चरण 2:डेटाबेस ऑब्जेक्ट की जांच करें

निम्न आश्रित (डी) डेटाबेस ऑब्जेक्ट्स को टेबल ड्रॉप होने पर छोड़ा जा सकता है:

  • बाधा (बाधाएं) डी

  • इंडेक्स (इंडेक्स) डी

  • MATERIALIZED_VIEW_LOG (भौतिक दृश्य लॉग) D

  • OBJECT_GRANT (वस्तु अनुदान) D

  • ट्रिगर (ट्रिगर) डी

निम्न SQL कमांड चलाएँ और आउटपुट को स्पूल फ़ाइल में सहेजें, जैसे किcons_trig_indx.txt :

set LINESIZE 500
set PAGESIZE 1000
SQL> spool cons_trig_indx.txt
SQL> select name, type, owner from all_dependencies where referenced_owner = 'TEST' and referenced_name = 'TABLEA';

NAME                TYPE              OWNER
--------------      --------------    -------
PROC_TABLEA         PROCEDURE         TEST
TABLEA_TRIGG        TRIGGER           TEST
PKG_TABLEA          PACKAGE BODY      TEST


SQL> select OWNER, INDEX_NAME, TABLE_OWNER, TABLE_NAME, STATUS, TABLESPACE_NAME
from dba_indexes where TABLE_OWNER='TEST' and TABLE_NAME='TABLEA';

OWNER   INDEX_NAME       TABLE_OWNER  TABLE_NAME   STATUS   TABLESPACE_NAME
---------------------------------------------------------------------------
TEST    TABLEA_IDX_ID01    TEST        TABLEA      VALID    TABLEA_TBL
TEST    TABLEA_IDX_ID04    TEST        TABLEA      VALID    TABLEA_TBL
TEST    TABLEA_IDX_PK      TEST        TABLEA      VALID    TABLEA_TBL


SQL> select STATUS, OBJECT_TYPE, OBJECT_NAME  from dba_objects
where OWNER='TEST' and OBJECT_TYPE = 'TRIGGER' and STATUS='INVALID';

no rows selected

SQL> select CONSTRAINT_NAME, CONSTRAINT_TYPE from dba_constraints
where TABLE_NAME='TABLEA' and owner='TEST';
SQL> spool off

CONSTRAINT_NAME     C
------------------  -----
SYS_C002004601      C
SYS_C002004602      C
SYS_C002004603      C
IDX_PK              P
FK01                R

चरण 3:TABLEA के DDL को कैप्चर करें

TABLEA की डेटा परिभाषा भाषा (DDL) को कैप्चर करने के लिए निम्न कमांड चलाएँ और स्क्रिप्ट को स्पूल फ़ाइल में सहेजें DEF_TABLEA.sql विभाजन तालिका बनाने से पहले:

set echo off
set feedback off
set linesize 160
set long 2000000
set pagesize 0
set trims on
column txt format a150 word_wrapped
SQL> spool DEF_TABLEA.sql
SQL> select DBMS_METADATA.GET_DDL('TABLE','TABLEA','TEST') txt FROM dual;
SQL> spool off

चरण 4:DDL स्क्रिप्ट कॉपी करें

चरण 3 में आपके द्वारा बनाई गई DDL स्क्रिप्ट को कॉपी करने के लिए निम्न कमांड चलाएँ।

cp DEF_TABLEA.sql DEF_TABLEA_PAR.sql

चरण 5:गैर-विभाजन तालिका में तिथियों की समीक्षा करें

TABLEA में दिनांक खोजने के लिए निम्न कमांड चलाएँ:

SQL> select * from (select DT from TEST.TABLEA where rownum <15 order by DT DESC);

चरण 6:DEF_TABLEA_PAR.sql फ़ाइल संपादित करें

संपादित करें DEF_TABLEA_PAR.sql निम्नलिखित परिवर्तन करने के लिए:

  • TABLEA . की सभी आवृत्तियां बदलें करने के लिए TABLEA_PAR

  • सभी बाधाओं को हटा दें, जैसे NOT NULL या कोई अन्य बाधा।

  • निम्न कमांड डालें ताकि टेबल एक नए टेबलस्पेस में बन जाए:

      TABLESPACE "TABLEA_TBL_PAR" LOGGING
    
  • चरण 5 में पहचानी गई तारीखों के आधार पर विभाजन परिभाषा जोड़ने के लिए निम्नलिखित कमांड डालें:

      PARTITION BY RANGE(DT)
      interval (numtoyminterval(1,'MONTH'))
      (partition TABLEA_2004  values less than  (to_date('01/01/2005','DD/MM/YYYY')),
       partition TABLEA_2005 values less than  (to_date('01/01/2006','DD/MM/YYYY')));
    

DEF_TABLEA_PAR.sql फ़ाइल अब निम्न उदाहरण की तरह दिखनी चाहिए:

CREATE TABLE "TEST"."TABLEA_PAR"
(    "ID" NUMBER(6,0),
     "CEID" NUMBER(6,0),
     "DT" DATE,
     "AMT" NUMBER(14,4),
     "RET" NUMBER(14,4),
     "CNT" NUMBER(4,0),
     "VCNT" NUMBER(4,0),
     "EXEDT" DATE,
     "LASTUPDBY" VARCHAR2(15),
     "VENUM" NUMBER(6,0),
     "LASTUPDDT" TIMESTAMP (6))
TABLESPACE "TABLEA_TBL_PAR" LOGGING
PARTITION BY RANGE(DT)
interval (numtoyminterval(1,'MONTH'))
(partition TABLEA_2004  values less than  (to_date('01/01/2005','DD/MM/YYYY')),
 partition TABLEA_2005  values less than  (to_date('01/01/2006','DD/MM/YYYY')));

चरण 7:विभाजन तालिका बनाएं

DEF_TABLEA_PAR.sql चलाने के लिए निम्न चरणों को चलाकर विभाजन तालिका बनाएं स्क्रिप्ट:

SQL> spool DEF_TABLEA_PAR.outp.txt
SQL> @DEF_TABLEA_PAR.sql

Table Created.

SQL> spool off

चरण 8:विभाजन तालिका सत्यापित करें

विभाजन तालिका को सत्यापित करने और परिभाषित विभाजनों को वापस करने के लिए निम्नलिखित कमांड चलाएँ:

SQL> spool verify_partition.txt
SQL> select partition_name from DBA_tab_partitions where table_name ='TABLEA_PAR' and table_owner = 'TEST';
SQL> spool off

PARTITION_NAME
-----------------
TABLEA_2004
TABLEA_2005

चरण 9:गैर-विभाजन तालिका पर आंकड़े एकत्र करें

गैर-विभाजन तालिका पर आंकड़े एकत्र करने और उन्हें स्पूल फ़ाइल में सहेजने के लिए निम्न आदेश चलाएँ।

SQL> SPOOL gather_stats.txt
SQL> exec dbms_stats.gather_table_stats ('TEST', 'TABLEA',cascade => TRUE);
SQL> spool off

चरण 10:पुनर्परिभाषा व्यवहार्यता जांचें

नोट :स्रोत तालिका (गैर-विभाजित) को आपके द्वारा पुनर्परिभाषित पैकेज का उपयोग करने से पहले प्राथमिक कुंजी की आवश्यकता नहीं है।

यह देखने के लिए कि क्या पुनर्परिभाषा संभव है, निम्न कमांड चलाएँ और परिणामों को स्पूल फ़ाइल में सहेजें:

SQL> spool check_the_redefinition.txt
SQL> EXEC DBMS_Redefinition.can_redef_table ('TEST', 'TABLEA');
SQL> spool off

चरण 11:पुनर्परिभाषा प्रारंभ करें

अगर check_the_redefinition.txt में कोई त्रुटि सूचीबद्ध नहीं है , निम्नलिखित लंबे समय से चल रहे कमांड का उपयोग करके पुनर्परिभाषा शुरू करें:

SQL> spool start_redef_table.txt
SQL>begin
    dbms_redefinition.start_redef_table
    (
     uname => 'TEST',
     orig_table => 'TABLEA',
     int_table => 'TABLEA_PAR');
     end;
   /
SQL> spool off

चरण 12:पुनर्परिभाषा के दौरान टेबलस्पेस त्रुटियों के लिए देखें

चरण 11 में पुनर्परिभाषित कार्रवाई के परिणामस्वरूप निम्नलिखित उदाहरण जैसे टेबलस्पेस अलर्ट हो सकते हैं:

ERROR at line 1:
ORA-12008: error in materialized view refresh path
ORA-01688: unable to extend table TEST.TABLEA_PAR
partition SYS_P42 by 1024 in tablespace TABLEA_TBL
ORA-06512: at "SYS.DBMS_REDEFINITION", line 52
ORA-06512: at "SYS.DBMS_REDEFINITION", line 1646
ORA-06512: at line 2

ERROR at line 1:
ORA-12008: error in materialized view refresh path
ORA-14400: inserted partition key does not map to any partition
ORA-06512: at "SYS.DBMS_REDEFINITION", line 52
ORA-06512: at "SYS.DBMS_REDEFINITION", line 1646
ORA-06512: at line 2

यदि आप पिछले उदाहरण के समान टेबलस्पेस त्रुटियाँ देखते हैं, तो आपको निम्नलिखित कदम उठाने चाहिए:

  1. पुनर्परिभाषा प्रक्रिया को रोकने के लिए निम्न आदेश चलाएँ।

     SQL> spool abort_redef_table.txt
     SQL> begin
          dbms_redefinition.abort_redef_table
          (
          uname => 'TEST',
          orig_table => 'TABLEA',
          int_table => 'TABLEA_PAR');
          end;
         /
     SQL> spool off
    
  2. विभाजन तालिका और भौतिक दृश्य को छोड़ दें।

  3. टेबलस्पेस का आकार बढ़ाएं। इस उदाहरण में, आपको टेबलस्पेस TABLEA_TBL का आकार बढ़ाना चाहिए।

  4. चरण 11 फिर से चलाएँ।

चरण 13:पुनर्परिभाषा त्रुटियों की जांच करें

पुनर्परिभाषित प्रक्रिया सफलतापूर्वक पूर्ण होने के बाद, किसी भी त्रुटि की जांच के लिए निम्न आदेश चलाएँ:

SQL> spool copy_table_dependents.txt
SQL> SET SERVEROUTPUT ON
     DECLARE
     l_num_errors PLS_INTEGER;
     BEGIN
       DBMS_REDEFINITION.copy_table_dependents(
           uname             => 'TEST',
           orig_table        => 'TABLEA',
           int_table         => 'TABLEA_PAR',
           copy_indexes      => DBMS_REDEFINITION.cons_orig_params, -- Non-Default
           num_errors        => l_num_errors);
           DBMS_OUTPUT.put_line('l_num_errors=' || l_num_errors);
     END;
/
SQL> spool off

यदि पुनर्परिभाषा सफल रही, तो आपको copy_table_dependents.txt में निम्न के समान परिणाम दिखाई देने चाहिए फ़ाइल:

l_num_errors=0
PL/SQL procedure successfully completed.

चरण 14:(वैकल्पिक) विभाजन तालिका को फिर से सिंक्रनाइज़ करें

यदि आप चाहें, तो अंतरिम नाम के साथ पार्टीशनटेबल को फिर से सिंक्रोनाइज़ करने के लिए निम्न कमांड चलाएँ:

SQL> spool sync_interim_table.txt
SQL>
     BEGIN
       DBMS_REDEFINITION.sync_interim_table
       (
           uname => 'TEST',
           orig_table => 'TABLEA',
           int_table => 'TABLEA_PAR');
      END;
/
SQL> spool off

चरण 15:विभाजन तालिका पर आंकड़े एकत्र करें

विभाजन तालिका पर आंकड़े एकत्र करने के लिए निम्नलिखित कमांड चलाएँ:

SQL> spool gather_statistics_par.txt
SQL> exec dbms_stats.gather_table_stats ('TEST', 'TABLEA_PAR',cascade => TRUE);
SQL> spool off

चरण 16:बाधा स्क्रिप्ट बनाएं

मान्य बाधा को सक्षम करने के लिए एक स्क्रिप्ट तैयार करने के लिए निम्नलिखित कमांड चलाएँ।

SQL> spool constraint_enable_validate.txt
SET LINESIZE 500
SET PAGESIZE 1000

SQL> select 'alter table' ||' '||OWNER||'.'||TABLE_NAME||' enable validate constraint'||' '||CONSTRAINT_NAME||';' from dba_constraints where TABLE_NAME = 'TABLEA_PAR' and OWNER='TEST';

'ALTERTABLE'||''||OWNER||'.'||TABLE_NAME||'ENABLEVALIDATECONSTRAINT'||''||CONSTR
--------------------------------------------------------------------------------
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_SYS_C002004601;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_SYS_C002004602;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_SYS_C002004603;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_IDX_PK;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_FK01;

SQL> spool off

चरण 17:मान्य बाधा सक्षम करें

चरण 16 द्वारा निर्मित स्क्रिप्ट और कमांड चलाएँ, जैसा कि निम्नलिखित उदाहरण में दिखाया गया है:

SQL> spool constraint_enable_execute.outp.txt
SQL>@constraint_enable.sql

alter table TEST.TABLEA_PAR enable validate constraint TMP$$_SYS_C002004601;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_SYS_C002004602;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_SYS_C002004603;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_IDX_PK;
alter table TEST.TABLEA_PAR enable validate constraint TMP$$_FK01;

SQL> spool off

चरण 18:गैर-विभाजन और विभाजन तालिकाओं की तुलना करें

मूल, गैर-विभाजन तालिका की तुलना नई, विभाजन तालिका से करें ताकि यह सत्यापित किया जा सके कि सभी विशेषताएँ समान हैं।

चरण 19:तालिकाओं का नाम बदलें

तालिका नामों को बदलने के लिए अंतरिम तालिका को वास्तविक तालिका के रूप में सेट करने के लिए निम्न आदेश चलाएँ:

SQL> spool finish_redef_table.txt
     BEGIN
       DBMS_REDEFINITION.finish_redef_table
      (
        uname => 'TEST',
        orig_table => 'TABLEA',
        int_table => 'TABLEA_PAR');
     END;
/

--------------------------------------------
@?/rdbms/admin/utlrp.sql
--------------------------------------------

SQL>spool off

चरण 20:तालिकाओं की तुलना करें

दोनों तालिकाओं की रिकॉर्ड संख्या की तुलना करने के लिए निम्न आदेश चलाएँ और सुनिश्चित करें कि वे मेल खाते हैं:

SQL> spool table_count.outp.txt
SQL> select count(*) from TEST.TABLEA;

 COUNT(*)
----------
  890540

SQL> select count (*) from TEST.TABLEA_PAR;

 COUNT(*)
----------
  890540

SQL> spool off

चरण 21:विभाजन की सफलता सत्यापित करें

यह सत्यापित करने के लिए कि विभाजन प्रक्रिया सफल रही, निम्नलिखित कमांड चलाएँ:

SQL> spool check_partition.txt
SQL> select partitioned from dba_tables where table_name = 'TABLEA' and owner='TEST';

PAR
------
YES

SQL> select partition_name , SUBPARTITION_COUNT, TABLESPACE_NAME from dba_tab_partitions where table_name='TABLEA' and table_owner='TEST';
SQL> select table_name, partition_name, high_value, partition_position from DBA_tab_partitions where table_name='TABLEA' and table_owner='TEST';
SQL> spool off

चरण 22:डेटाबेस ऑब्जेक्ट की दोबारा जांच करें

डेटाबेस ऑब्जेक्ट की जांच करने के लिए निम्न आदेश चलाएँ और चरण 2 के परिणामों की तुलना करें:

SET LINESIZE 500
SET PAGESIZE 1000
SQL> spool cons_indx_trigg.txt
SQL> select name, type, owner from all_dependencies where referenced_owner = 'TEST' and referenced_name = 'TABLEA';

NAME                TYPE              OWNER
----------------    ---------------   ------------
PROC_TABLEA         PROCEDURE         TEST
TABLEA_TRIGG        TRIGGER           TEST
PKG_TABLEA          PACKAGE BODY      TEST

SQL> select OWNER, INDEX_NAME, TABLE_OWNER, TABLE_NAME, STATUS, TABLESPACE_NAME from dba_indexes where TABLE_OWNER='TEST' and TABLE_NAME='TABLEA';

OWNER  INDEX_NAME       TABLE_OWNER TABLE_NAME  STATUS   TABLESPACE_NAME
------------------------------------------------------------------------
TEST   TABLEA_IDX_ID01  TEST        TABLEA      VALID    TABLEA_TBL
TEST   TABLEA_IDX_ID04  TEST        TABLEA      VALID    TABLEA_TBL
TEST   TABLEA_IDX_PK    TEST        TABLEA      VALID    TABLEA_TBL

SQL> select STATUS, OBJECT_TYPE, OBJECT_NAME  from dba_objects where OWNER='TEST' and OBJECT_TYPE = 'TRIGGER' and STATUS='INVALID';

no rows selected

SQL> select CONSTRAINT_NAME, CONSTRAINT_TYPE from dba_constraints where TABLE_NAME='TABLEA' and owner='TEST';

CONSTRAINT_NAME        C
-------------------		----------
SYS_C002004601         C
SYS_C002004602         C
SYS_C002004603         C
IDX_PK                 P
FK01                   R

12 rows selected.

SQL> spool off

चरण 23:अनुक्रमणिका का पुनर्निर्माण करें

नए टेबलस्पेस पर इंडेक्स को फिर से बनाने के लिए निम्न कमांड चलाएँ:

SQL> spool rebuild_indx.txt
SQL>@rebuild_index.sql

ALTER INDEX TEST.TABLEA_IDX_ID01 REBUILD TABLESPACE TABLEA_TBL_PAR ONLINE;
ALTER INDEX TEST.ITABLEA_IDX_ID04 REBUILD TABLESPACE TABLEA_TBL_PAR ONLINE;
ALTER INDEX TEST.TABLEA_IDX_PK REBUILD TABLESPACE TABLEA_TBL_PAR ONLINE;

SQL> spool off

चरण 24:अनुक्रमणिका सत्यापित करें

यह सत्यापित करने के लिए निम्न आदेश चलाएँ कि स्थिति valid है और सभी इंडेक्स के लिए टेबल स्पेस TABLEA_TBL_PAR है:

SQL> spool verify_indx.outp.txt
SQL> select OWNER, INDEX_NAME, TABLE_OWNER, TABLE_NAME, STATUS, TABLESPACE_NAME from dba_indexes where TABLE_OWNER='TEST' and TABLE_NAME='TABLEA';

OWNER  INDEX_NAME       TABLE_OWNER  TABLE_NAME   STATUS   TABLESPACE_NAME
---------------------------------------------------------------------------
TEST   TABLEA_IDX_ID01  TEST         TABLEA       VALID   	 TABLEA_TBL_PAR
TEST   TABLEA_IDX_ID04  TEST         TABLEA       VALID   	 TABLEA_TBL_PAR
TEST   TABLEA_IDX_PK    TEST         TABLEA       VALID     TABLEA_TBL_PAR

SQL>spool off

चरण 25:मूल गैर-विभाजन तालिका छोड़ें

डीबीए ने पुष्टि की है कि सब कुछ अच्छा लग रहा है, मूल तालिका को हटाने के लिए निम्न आदेश निष्पादित करें, जिसमें अब अंतरिम तालिका का नाम है, TEST.TABLEA_PAR:

SQL> DROP table TEST.TABLEA_PAR cascade constraints;

निष्कर्ष

पूर्ववर्ती चरणों ने तालिका को विभाजित करने के लिए अंतरिम तालिका, TEST.TABLEA_PAR का उपयोग किया, TEST.TABLEA, बिना किसी एप्लिकेशन डाउनटाइम के एक श्रेणी अंतराल तालिका में।

कोई टिप्पणी करने या प्रश्न पूछने के लिए प्रतिक्रिया टैब का उपयोग करें।


  1. Oracle प्रपत्र APP_MULTI पैकेज का उपयोग करें

    Oracle® APP_MULTI पैकेज आपको एक फॉर्म में बहु-चयन कार्यक्षमता जोड़ने में सक्षम बनाता है। यह विकल्प APPCORE लाइब्रेरी में उपलब्ध है। APP_MULTI पैकेज का उपयोग करके, आप एकल या एकाधिक रिकॉर्ड का चयन कर सकते हैं और आवश्यकतानुसार उन्हें संसाधित कर सकते हैं। निम्न छवि यादृच्छिक रिकॉर्ड चयन को दर्शाती है:

  1. Oracle 19c में DBCA कमांड का उपयोग करके डेटाबेस क्लोन करना

    यह ब्लॉग डेटाबेस कॉन्फ़िगरेशन सहायक (DBCA) का उपयोग करने के तरीकों का परिचय देता है, Oracle 19c में एक नई सुविधा, स्रोत डेटाबेस का बैकअप लिए बिना एक दूरस्थ प्लग करने योग्य डेटाबेस (PDB) को एक कंटेनर डेटाबेस (CDB) में क्लोन करने के लिए। स्रोत से लक्ष्य तक क्लोन करने में कम से कम समय लगता है। स्रोत D

  1. Oracle SQL प्रोफ़ाइल और आधार रेखा

    यह पोस्ट Oracle® में SQL प्रोफ़ाइल और बेसलाइन के बीच अंतर को हाइलाइट करती है और बताती है कि क्वेरी को ट्यून करते समय यह कैसे काम करता है। अनुकूलक, प्रोफ़ाइल और आधार रेखा उच्च स्तर पर, ये तीन तत्व एक साथ निम्न प्रकार से कार्य करते हैं: क्वेरी ऑप्टिमाइज़र क्वेरी निष्पादन के लिए सर्वोत्तम योजना प्र