Oracle 11G中的Edition-Based Redefinition(CrossEdition)

    技术2024-10-31  28

    11.2不但增加了版本的功能,而且还提供了不停机的版本升级功能。为了保证在升级版本的过程中,用户仍然可以访问数据,Oracle提供了CROSSEDITION触发器来处理版本升级或降级过程中的数据问题。简单的说,CROSSEDITION触发器可以其他的版本中生效,使得登陆到其他版本的会话执行的DML可以正确的将数据应用到当前版本。如果是升级版本,使用FORWARD CROSSEDITION触发器,这个触发器在当前版本的父版本中触发。如果是降级版本,使用REVERSE CROSSEDITION触发器,这个触发器在当前版本和子版本中触发。

     

    CREATE TABLE T_PERSON (ID NUMBER PRIMARY KEY, FIRST_NAME VARCHAR2(30), LAST_NAME VARCHAR2(30));

     

    INSERT INTO T_PERSON SELECT ROWNUM, OBJECT_NAME, OBJECT_TYPEFROM USER_OBJECTS;

     

    CREATE EDITION E_1;

    ALTER SESSION SET EDITION = E_1;

    ALTER TABLE T_PERSON ADD FULL_NAME VARCHAR2(60);

     

    CREATE or replace TRIGGER T_CROSSEDITION_PERSON BEFORE INSERT OR UPDATE ON T_PERSONFOR EACH ROW CROSSEDITIONBEGIN:NEW.FULL_NAME := :NEW.FIRST_NAME || :NEW.LAST_NAME;END;

     

    ALTER SESSION SET EDITION = ORA$BASE;

     

    select * from T_PERSON;

     

    alter user chandler enable editions;--make the schema enabled editions.

     

    INSERT INTO T_PERSON(ID, FIRST_NAME, LAST_NAME, full_name) values(14, 'Tom', 'Bill','Tom Bill');commit;

     

    INSERT INTO T_PERSON(ID, FIRST_NAME, LAST_NAME) values(15, 'Tom', ' Bill');commit;

     

    CREATE OR REPLACE PROCEDURE hello IS  BEGIN    DBMS_OUTPUT.PUT_LINE('Hello, edition 2.');  END hello;

     

    beginhello();end;

     

    当新版本升级完成,旧版本数据全部转化后,将数据库的默认版本设置为新版本,则升级工作完成,CROSSEDITION触发器的历史使命也最终完成。

    SELECT property_value FROM   database_propertiesWHERE  property_name = 'DEFAULT_EDITION';

     

    SELECT * FROM dba_editions;

     

    ALTER DATABASE DEFAULT EDITION = edition-name;

     

    SELECT * FROM dba_editions;GRANT USE ON EDITION release_v1 TO edition_test;DROP EDITION release_v2;

    最新回复(0)