暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

探究 Oracle PDB Application Container (五)

1375

编者按:

本文作者系大连健哥,POSTGRESQL、ORACLE 数据库资深从业人员、IT 技术的深度爱好者。相信科学改变人类、技术创造未来。个人主页:https://www.cnblogs.com/gaojian/,经其本人授权发布。

【免责声明】本公众号文章仅代表个人观点,与任何公司无关。

探究 Oracle PDB Application Container (四)

在使用 Application Container 时,当我们定义Application 中的一个共通对象为 extended data 的时候,Application 中的共通数据,和 Application PDB 中的独立数据,会一起出现在查询结果中,导致一些特殊的问题(比如数据重复)。

下面是测试的过程,首先,构造测试用的 Application container 、Application、Application PDB。

    alter system set db_create_file_dest='/refresh/home/cpdest';

    CREATE PLUGGABLE DATABASE appcon1 AS APPLICATION CONTAINER ADMIN USER app_admin IDENTIFIED BY Password1;
    ALTER PLUGGABLE DATABASE appcon1 OPEN;
    ALTER SESSION SET container = appcon1;
    CREATE PLUGGABLE DATABASE apppdb1 ADMIN USER pdb_admin IDENTIFIED BY Password1;
    ALTER PLUGGABLE DATABASE apppdb1 OPEN;

    CREATE PLUGGABLE DATABASE apppdb2 ADMIN USER pdb_admin IDENTIFIED BY Password1;
    ALTER PLUGGABLE DATABASE apppdb2 OPEN;


    ALTER SESSION SET container = appcon1;
    ALTER PLUGGABLE DATABASE APPLICATION ref_app BEGIN INSTALL '1.0';

    CREATE TABLESPACE app_ts DATAFILE SIZE 1M AUTOEXTEND ON NEXT 1M;
    CREATE USER app_user IDENTIFIED BY app_user
    DEFAULT TABLESPACE app_ts
    QUOTA UNLIMITED ON app_ts
    CONTAINER=ALL;
    GRANT CREATE SESSION, CREATE TABLE TO app_user;
    CREATE TABLE app_user.reference_data SHARING= EXTENDED DATA (
    id NUMBER,
    description VARCHAR2(50),
    CONSTRAINT t1_pk PRIMARY KEY (id)
    );

    INSERT INTO app_user.reference_data
    SELECT level,
    'Description of ' || level
    FROM dual
    CONNECT by level <= 5;

    COMMIT;

    ALTER PLUGGABLE DATABASE APPLICATION ref_app END INSTALL;

     

    这里,我定义 table app_user.reference_data 时,使用了 SHARING= EXTENDED DATA。我给了它5条数据。我先试试看能否插入同样ID(例如:ID=5)的数据:

      SQL>  alter session set container=apppdb1;

      Session altered.

      SQL>
      SQL> ALTER PLUGGABLE DATABASE APPLICATION ALL SYNC;

      Pluggable database altered.

      SQL> select * from app_user.reference_data;

      ID DESCRIPTION
      ---------- --------------------------------------------------
      1 Description of 1
      2 Description of 2
      3 Description of 3
      4 Description of 4
      5 Description of 5


      SQL> insert into app_user.reference_data(id,description) values(5,'Desp5');
      insert into app_user.reference_data(id,description) values(5,'Desp5')
      *
      ERROR at line 1:
      ORA-00001: unique constraint (APP_USER.T1_PK) violated


      SQL>

      还不错,因为 Application 中的这个表,有主键约束,在已经有 ID=5 的数据的同时,我在 Appcation PDB 中,是无法再插入 ID =5 的数据的。

       

      但是,如果我在 Application PDB 中插入 ID=6 的新数据,然后回到 Application 进行升级,在 Application 中,也插入 ID=6 的数据,会如何呢?

        SQL>  alter session set container=apppdb1;

        Session altered.

        SQL>
        SQL> ALTER PLUGGABLE DATABASE APPLICATION ALL SYNC;

        SQL> insert into app_user.reference_data(id, description) values(6,'Desp6');

        1 row created.

        SQL> commit;

        Commit complete.


        SQL> alter session set container=appcon1;

        Session altered.

        SQL> ALTER PLUGGABLE DATABASE APPLICATION ref_app BEGIN UPGRADE '1.0' TO '1.1';

        Pluggable database altered.

        SQL> insert into app_user.reference_data(id, description) values(6,'Descrption 6');

        1 row created.

        SQL> commit;

        Commit complete.

        SQL> ALTER PLUGGABLE DATABASE APPLICATION ref_app END UPGRADE;

        Pluggable database altered.

        SQL>

         

        可以看到,在Application 的升级过程里,插入同样 ID=6 的数据,成功了,Application 无视了 Application PDB 中的内容。

        那么,我再回到 Application PDB中,会看到怎样的景象呢?

          SQL> alter session set container=apppdb1;

          Session altered.

          SQL> ALTER PLUGGABLE DATABASE APPLICATION ALL SYNC;

          Pluggable database altered.

          SQL> select * from app_user.reference_data;

          ID DESCRIPTION
          ---------- --------------------------------------------------
          1 Description of 1
          2 Description of 2
          3 Description of 3
          4 Description of 4
          5 Description of 5
          6 Descrption 6
          6 Desp6

          7 rows selected.

          SQL>

          可以看到, 在 Application PDB 中,看到了ID=6 的重复数据。看来,使用 Application container、Application 时,还是要从业务层面制定好规则,确定什么样的数据可以在 Application 中共享。

          后续文章更加精彩,欢迎关注本公众号或访问【阅读原文】。

          ——End——

          专注于技术不限于技术!

          用碎片化的时间,一点一滴地提高数据库技术和个人能力。

          欢迎关注!

          备份恢复系列:

          Oracle数据库工程师手记:备份恢复双城记(一)

          Oracle数据库工程师手记:备份恢复双城记(二)

          Oracle数据库工程师手记:备份恢复双城记(三)

          Oracle数据库工程师手记:从RAC环境备份后向新环境(文件系统)恢复的试验

          Oracle数据库工程师手记:探究 Oracle PDB Application Container (一)

          Oracle数据库工程师手记:探究 Oracle PDB Application Container (二)

          Oracle数据库工程师手记:  探究 Oracle PDB Application Container (三)

          Oracle数据库工程师手记:探究 Oracle PDB Application Container (四)

          Oracle数据库工程师手记:如何在Active Data Guard环境下创建Standby的AWR

          Oracle数据库工程师手记:Data Guard Broker中改属性是否需要两侧分别执行?

          文章转载自Oracle数据库技术,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

          评论