[Oracle]包含了MVIEW的表领域,在进行导出,表领域改名,再导入后,MVIEW会消失不见。

简介:

包含了MVIEW的表领域,在进行导出,表领域改名,再导入后,MVIEW会消失不见。 

测试环境12.1.0.2

=================
步骤1:数据的准备

[oracle@db12102 admin]$ sqlplus / as sysdba

SQL*Plus: Release 12.1.0.2.0 Production on 木 8月 17 13:01:48 2017
...

SQL> alter session set container=pdb1;
SQL> create tablespace userdata1 datafile '/home/oracle/data5.dbf' size 20M;


SQL> grant dba to user001 identified by user001;
SQL> alter user user001 default tablespace userdata1;


SQL> conn user001/user001@mypdb1

SQL> create table journal_tab001(ss_pk integer primary key, base_date date, cancel_date date,app_date date);
SQL> create materialized view log on journal_tab001;

SQL> insert into journal_tab001 values(1,sysdate,sysdate,sysdate);
SQL> insert into journal_tab001 values(2,sysdate,sysdate,sysdate);
SQL> insert into journal_tab001 values(3,sysdate,sysdate,sysdate);
SQL> commit;

创建 MVIEW:

SQL> create materialized view journal_tab001_MDATE_MV  TABLESPACE USERDATA1
       AS SELECT  ss_pk, 
                  MAX (GREATEST (base_date, NVL (cancel_date,TO_DATE ('00010101', 'yyyymmdd')),app_date) ) basedate 
          FROM journal_tab001 GROUP BY ss_pk;  2

SQL> select * from journal_tab001_MDATE_MV;

SS_PK          BASEDATE
-------------- --------
            1 17-08-17
            2 17-08-17
            3 17-08-17

=================
步骤2:数据的导出

SQL> create or replace directory DATAPUMP_DIR_D001 as '/home/oracle';

SQL> show con_name;

CON_NAME
------------------------------
PDB1
SQL>

以表领域 模式导出:

[oracle@db12102 ~]$ expdp "'"sys/oracle@mypdb1 as sysdba"'" tablespaces=USERDATA1 directory=DATAPUMP_DIR_D001 dumpfile=userdata1.dmp logfile=userdata1_export.log

Export: Release 12.1.0.2.0 - Production on 木 8月 17 13:39:02 2017

Copyright (c) 1982, 2014, Oracle and/or its affiliates.  All rights reserved.

Connect to: Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
"SYS". "SYS_EXPORT_TABLESPACE_01" is running: "sys / ******** @ mypdb1 AS SYSDBA" tablespaces = USERDATA1 directory = DATAPUMP_DIR_D001 dumpfile = userdata1.dmp logfile = userdata1_export.log
Estimating using BLOCKS method ...
Processing of object type TABLE_EXPORT / TABLE / TABLE_DATA
Total estimates using the BLOCKS method: 192 KB
Processing of object type TABLE_EXPORT / TABLE / TABLE
Processing of object type TABLE_EXPORT / TABLE / COMMENT
Processing of object type TABLE_EXPORT / TABLE / INDEX / INDEX
Processing of object type TABLE_EXPORT / TABLE / INDEX / FUNCTIONAL_INDEX / INDEX
Processing of object type TABLE_EXPORT / TABLE / CONSTRAINT / CONSTRAINT
Processing of object type TABLE_EXPORT / TABLE / INDEX / STATISTICS / INDEX_STATISTICS
Processing of object type TABLE_EXPORT / TABLE / INDEX / STATISTICS / FUNCTIONAL_INDEX / INDEX_STATISTICS
Processing of object type TABLE_EXPORT / TABLE / STATISTICS / TABLE_STATISTICS
Processing of object type TABLE_EXPORT / TABLE / STATISTICS / MARKER
Processing of object type TABLE_EXPORT / TABLE / POST_TABLE_ACTION
. "user001". "journal_tab001" 6.445 KB 3 rows have been exported
. "user001". "journal_tab001_MDATE_MV" 5.984 KB 3 rows have been exported
. "user001". "MLOG $ _journal_tab001" 7.273 KB 3 rows have been exported
Master table "SYS". "SYS_EXPORT_TABLESPACE_ 01" has been successfully loaded / unloaded
************************************************** ****************************
The dump file set to SYS.SYS_EXPORT_TABLESPACE_01 is as follows:
 /home/oracle/userdata1.dmp
Job "SYS". "SYS_EXPORT_TABLESPACE_01" completed successfully with tree August 17 13:39:55 2017 elapsed 0 00: 00: 50

[oracle@db12102 ~]$

===

SQL> set pages 0
SQL> set longchunksize 3000
SQL> set long 2000000000

SQL> select dbms_metadata.get_ddl('MATERIALIZED_VIEW','journal_tab001_MDATE_MV','user001') from dual;

 CREATE MATERIALIZED VIEW "user001"."journal_tab001_MDATE_MV" ("ss_pk", "BASEDATE")
 ORGANIZATION HEAP 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 "USERDATA1"
 BUILD IMMEDIATE
 USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255
 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 "USERDATA1"
 REFRESH FORCE ON DEMAND
 USING DEFAULT LOCAL ROLLBACK SEGMENT
 USING ENFORCED CONSTRAINTS DISABLE QUERY REWRITE
 AS SELECT  ss_pk, MAX (GREATEST (base_date, NVL (cancel_date,TO_
DATE ('00010101', 'yyyymmdd')),app_date) ) basedate FROM journal_tab001 GROUP BY ss_pk

SQL>

SQL> alter tablespace USERDATA1 rename to USEROLD; <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<   为了导出作准备,原有表领域改名

SQL> select dbms_metadata.get_ddl('MATERIALIZED_VIEW','journal_tab001_MDATE_MV','user001') from dual;

 CREATE MATERIALIZED VIEW "user001"."journal_tab001_MDATE_MV" ("ss_pk", "
BASEDATE")
 ORGANIZATION HEAP 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 "USEROLD"
 BUILD IMMEDIATE
 USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255
 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 "USEROLD"
 REFRESH FORCE ON DEMAND
 USING DEFAULT LOCAL ROLLBACK SEGMENT
 USING ENFORCED CONSTRAINTS DISABLE QUERY REWRITE
 AS SELECT  ss_pk, MAX (GREATEST (base_date, NVL (cancel_date,TO_
DATE ('00010101', 'yyyymmdd')),app_date) ) basedate FROM journal_tab001 GROUP BY ss_pk

SQL>

SQL> create tablespace USERDATA1 LOGGING DATAFILE '/home/oracle/data6.dbf' SIZE 20M; <<<<<<<<<<<<<<<<<<<<<<<<<,创建同名的表领域

SQL> select object_id,object_name,object_type, status from dba_objects where owner='user001' order by object_id;  [***1]

    91961 journal_tab001                    TABLE                          VALID
    91962 SYS_C0010023                     INDEX                          VALID
    91963 MLOG$_journal_tab001              TABLE                          VALID
    91964 RUPD$_journal_tab001              TABLE                          VALID
    91965 I_MLOG$_journal_tab001            INDEX                          VALID
    91966 journal_tab001_MDATE_MV           TABLE                          VALID
    91967 I_SNAP$_journal_tab001_MAXDAT     INDEX                          VALID
    91968 journal_tab001_MDATE_MV           MATERIALIZED VIEW              VALID

SQL>

=================
步骤3:数据的导入

[oracle @ db12102 ~] $ impdp "'" sys / oracle @ mypdb1 as sysdba "'" tablespaces = USERDATA1 directory = DATAPUMP_DIR_D001 dumpfile = userdata1.dmp logfile = userdata1_import.log table_exists_action = replace

Import: Release 12.1.0.2.0 - Production on Tree August 17 13:45:58 2017

Copyright (c) 1982, 2014, Oracle and / or its affiliates. All rights reserved.

Connect to: Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
The master table "SYS". "SYS_IMPORT_TABLESPACE_ 02" was successfully loaded / unloaded
"SYS". "SYS_IMPORT_TABLESPACE_02" is running: "sys / ******** @ mypdb1 AS SYSDBA" tablespaces = USERDATA1 directory = DATAPUMP_DIR_D001 dumpfile = userdata1.dmp logfile = userdata1_import.log table_exists_action = replace
Processing of object type TABLE_EXPORT / TABLE / TABLE
Processing of object type TABLE_EXPORT / TABLE / TABLE_DATA
. "user001". "journal_tab001" 6.445 KB 3 rows imported
. "user001". "journal_tab001_MDATE_MV" 5.984 KB 3 rows imported
. "user001". "MLOG $ _journal_tab001" 7.273 KB 3 rows imported
Processing of object type TABLE_EXPORT / TABLE / COMMENT
Processing of object type TABLE_EXPORT / TABLE / INDEX / INDEX
Processing of object type TABLE_EXPORT / TABLE / INDEX / FUNCTIONAL_INDEX / INDEX
Processing of object type TABLE_EXPORT / TABLE / CONSTRAINT / CONSTRAINT
Processing of object type TABLE_EXPORT / TABLE / INDEX / STATISTICS / INDEX_STATISTICS
Processing of object type TABLE_EXPORT / TABLE / INDEX / STATISTICS / FUNCTIONAL_INDEX / INDEX_STATISTICS
Processing of object type TABLE_EXPORT / TABLE / STATISTICS / TABLE_STATISTICS
Processing of object type TABLE_EXPORT / TABLE / STATISTICS / MARKER
Processing of object type TABLE_EXPORT / TABLE / POST_TABLE_ACTION
Job "SYS". "SYS_IMPORT_TABLESPACE_02" completed successfully with tree August 17 13:46:18 2017 elapsed 0 00: 00: 17


SQL> select object_id,object_name,object_type, status from dba_objects where owner='user001' order by object_id;   [***2]

    92014 journal_tab001                    TABLE                          VALID
    92015 MLOG$_journal_tab001              TABLE                          VALID
    92016 journal_tab001_MDATE_MV           TABLE                          VALID
    92017 I_MLOG$_journal_tab001            INDEX                          VALID
    92018 I_SNAP$_journal_tab001_MAXDAT     INDEX                          VALID
    92019 SYS_C0010034                      INDEX                          VALID


对比上面的 [***1] 和 [**2], 可以发现,缺少了几个内部表。journal_tab001_MDATE_MV 也不见了。


SQL>
SQL> select dbms_metadata.get_ddl ('MATERIALIZED_VIEW', 'journal_tab001_MDATE_MV', 'user001') from dual;
ERROR:
ORA-31603: Object "journal_tab001_MDATE_MV" (type MATERIALIZED_VIEW) not found in schema "user001". ORA-06512:
"SYS.DBMS_METADATA", line 6069
ORA-06512: "SYS.DBMS_METADATA", line 8666
ORA-06512: Row 1

no record selected.

事实上,即便是如下的方式来进行,导入后也会发现 mview 不见了。
   Export、MVIEW删除、表领域改名、再新建一个同名表领域、Import (过程略)


此现象,是否是 Bug, 是不明确的。 在如下几种环境中都会发生:

  11.2.0.4
12.1.0.2 Non-CDB
12.1.0.2 CDB/PDB
   12.2.0.1 Non-CDB
   12.2.0.1 CDB/PDB


对策是 :

通过 Schema 模式来进行导出/导入。






本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/p/7596127.html,如需转载请自行联系原作者

目录
相关文章
|
7月前
|
Oracle 关系型数据库 数据库
Oracle查询优化-复制表的定义及数据
【1月更文挑战第5天】【1月更文挑战第14篇】在Oracle数据库中,复制表定义和复制表数据是两个常见的操作。
115 1
|
7月前
|
消息中间件 关系型数据库 Kafka
实时计算 Flink版产品使用合集之oracle cdc 抽取新增一张表 可以从savepoint恢复吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
5月前
|
Oracle 关系型数据库 Java
Oracle数据库导入工具IMP详解与用法
Oracle数据库导入工具IMP详解与用法
|
6月前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用问题之oracle无主键的表支持同步吗如何实现
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
6月前
|
运维 DataWorks Oracle
DataWorks产品使用合集之在标准模式下,当同步Oracle的表或视图时,是否需要在源端的测试和生产环境中都存在要同步的表或视图
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
54 3
|
6月前
|
Oracle 关系型数据库 Java
Oracle数据库导入工具IMP详解与用法
Oracle数据库导入工具IMP详解与用法
|
7月前
|
资源调度 Oracle 关系型数据库
实时计算 Flink版产品使用合集之同步Oracle数据时,一张表产生了大量的连接数,如何处理
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
6月前
|
存储 SQL Oracle
oracle 存储过程导出sql语句 导出为文件
oracle 存储过程导出sql语句 导出为文件
190 0
|
7月前
|
SQL Oracle 关系型数据库
Oracle 数据泵导出导入(映射表空间、Schema)
Oracle 数据泵导出导入(映射表空间、Schema)
|
7月前
|
SQL 存储 Oracle
Oracle中的Dual表:数据世界的“神奇小盒子”
【4月更文挑战第19天】Oracle的Dual表是一个虚拟表,仅含一行一列,常用于执行SQL函数、数据类型转换、测试语句和动态SQL。它是测试和便捷操作的工具,如获取当前日期(`SELECT SYSDATE FROM DUAL`)、数字转字符串(`SELECT TO_CHAR(12345) FROM DUAL`)。在存储过程、函数和触发器中也发挥重要作用,是数据库管理员的得力助手。

推荐镜像

更多