Oracle传输表空间总结

0、准备工作创建传输的表空间 SQL create tablespace tbs_single datafile c:Oracleoradataora9ibs_single01.dbf size 100M extent management local; –创建用户,并将表空间作为默认表空间 SQL create user tranp identified by Oracle default t

0、准备工作
–创建被传输的表空间
SQL> create tablespace tbs_single
datafile ‘c:Oracleoradataora9ibs_single01.dbf’ size 100M
extent management local;
–创建用户,并将表空间作为默认表空间
SQL> create user tranp identified by Oracle default tablespace tbs_single;

SQL> grant connect,resource to tranp;
–在该表空间创建表,用于测试
SQL> create table tranp.t01 as select * from sys.dba_objects;
1、检查源、目标平台Endianness
在源数据库平台上:
SQL> SELECT d.PLATFORM_NAME, ENDIAN_FORMAT
  2       FROM V$TRANSPORTABLE_PLATFORM. tp, V$DATABASE d
  3       WHERE tp.PLATFORM_NAME = d.PLATFORM_NAME;
PLATFORM_NAME                          ENDIAN_FORMAT
————————————   ————–
Microsoft Windows IA (32-bit)                 Little

在目标数据库平台上:
SQL> SELECT d.PLATFORM_NAME, ENDIAN_FORMAT
     FROM V$TRANSPORTABLE_PLATFORM. tp, V$DATABASE d
     WHERE tp.PLATFORM_NAME = d.PLATFORM_NAME;
PLATFORM_NAME                          ENDIAN_FORMAT
————————————                    ————–
Linux IA (32-bit)                         Little
由于源和目标平台的Endianness一致,可以省去convert这一步。
2、检查要表空间是否自包含
SQL> EXECUTE DBMS_TTS.TRANSPORT_SET_CHECK(‘TBS_SINGLE’,true);
PL/SQL 过程已成功完成。
SQL> SELECT * FROM TRANSPORT_SET_VIOLATIONS;
未选定行
说明表空间是自包含的。
3、产生传输表空间集
创建目录对象
SQL> create DIRECTORY tranp_dir as ‘c:software’;
目录已创建。
SQL> grant read,write on DIRECTORY tranp_dir to public;
授权成功。
将表空间置为只读。
SQL> alter tablespace tbs_single read only;
表空间已更改。
使用数据泵导出传输表空间的元数据

注:如果Endianness不一致,还需要使用RMAN进行转换表空间的数据文件。
4、传送表空间集
将表空间的数据文件和导出的DMP文件,传送到目标数据库平台上。
5、导入表空间
在目标数据库中,创建相应的目录对象和用户。
SQL> create directory tranp_dir as ‘/home/Oracle’;
Directory created.

SQL> grant read,write on directory tranp_dir to public;
Grant succeeded.

SQL> create user tranp identified by Oracle;
User created.

SQL> grant connect,resource to tranp;
Grant succeeded.
使用数据库泵,导入到目标数据库中。
[Oracle@ocmu ~]$ impdp system/oracle dumpfile=TBSINGLE.DMP directory=tranp_dir transport_datafiles=/u01/app/oracle/oradata/PROD/TBS_SINGLE01.DBF remap_schema=tranp:tranp

Import: Release 10.2.0.1.0 – Production on Thursday, 30 August, 2012 23:40:25

Copyright (c) 2003, 2005, Oracle.  All rights reserved.

Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 – Production
With the Partitioning, OLAP and Data Mining options
Master table “SYSTEM”.”SYS_IMPORT_TRANSPORTABLE_01″ successfully loaded/unloaded
Starting “SYSTEM”.”SYS_IMPORT_TRANSPORTABLE_01″:  system/******** dumpfile=TBSINGLE.DMP directory=tranp_dir transport_datafiles=/u01/app/Oracle/oradata/PROD/TBS_SINGLE01.DBF remap_schema=tranp:tranp
Processing object type TRANSPORTABLE_EXPORT/PLUGTS_BLK
Processing object type TRANSPORTABLE_EXPORT/TABLE
Processing object type TRANSPORTABLE_EXPORT/POST_INSTANCE/PLUGTS_BLK
Job “SYSTEM”.”SYS_IMPORT_TRANSPORTABLE_01″ successfully completed at 23:40:29
将被导入的表空间置为read write。
SQL> alter tablespace TBS_SINGLE read write;
Tablespace altered.

6、测试
目标库中,进行测试。
SQL> select name from v$tablespace;

NAME
——————————
SYSTEM
UNDOTBS1
SYSAUX
USERS
TEMP
TBS_SINGLE
。。。。。。。。。。。。。。。。。
13 rows selected.

SQL> conn tranp/Oracle
Connected.
SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID
—————————— ——- ———-
T01                            TABLE

SQL> select count(*) from t01;

  COUNT(*)
———-
     49795

SQL> conn / as sysdba
Connected.

SQL> select TABLESPACE_NAME,STATUS from dba_tablespaces;

TABLESPACE_NAME                STATUS
—————————— ———
SYSTEM                         ONLINE
UNDOTBS1                       ONLINE
SYSAUX                         ONLINE
TEMP                           ONLINE
USERS                          ONLINE
TBS_SINGLE                     ONLINE
。。。。。。。。。。。。。。。。。。。。。。。。
13 rows selected.
7、问题
问题描述:
Oracle@ocmu ~]$ impdp system/oracle dumpfile=TBSINGLE.DMP directory=tranp_dir transport_datafiles=/u01/app/oracle/oradata/PROD/TBS_SINGLE01.DBF remap_schema=tranp:tranp

Import: Release 10.2.0.1.0 – Production on Thursday, 30 August, 2012 23:25:47

Copyright (c) 2003, 2005, Oracle.  All rights reserved.

Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 – Production
With the Partitioning, OLAP and Data Mining options
Master table “SYSTEM”.”SYS_IMPORT_TRANSPORTABLE_01″ successfully loaded/unloaded
Starting “SYSTEM”.”SYS_IMPORT_TRANSPORTABLE_01″:  system/******** dumpfile=TBSINGLE.DMP directory=tranp_dir transport_datafiles=/u01/app/Oracle/oradata/PROD/TBS_SINGLE01.DBF remap_schema=tranp:tranp
Processing object type TRANSPORTABLE_EXPORT/PLUGTS_BLK
ORA-39123: Data Pump transportable tablespace job aborted
ORA-29345: cannot plug a tablespace into a database using an incompatible character set

Job “SYSTEM”.”SYS_IMPORT_TRANSPORTABLE_01″ stopped due to fatal error at 23:25:53

a元数据库:
SQL> select tab1.aa||’_’||tab2.bb||’.’||tab3.cc from
  2   (select VALUE$ aa from sys.props$ where name=’NLS_LANGUAGE’)tab1,
  3   (select VALUE$ bb from sys.props$ where name=’NLS_ISO_CURRENCY’)tab2,
  4   (select VALUE$ cc from sys.props$ where name=’NLS_CHARACTERSET’)tab3;

TAB1.AA||’_’||TAB2.BB||’.’||TAB3.CC
———————————————————————-
AMERICAN_AMERICA.ZHS16GBK
b目标数据库:
SQL> select tab1.aa||’_’||tab2.bb||’.’||tab3.cc from
  2   (select VALUE$ aa from sys.props$ where name=’NLS_LANGUAGE’)tab1,
  3   (select VALUE$ bb from sys.props$ where name=’NLS_ISO_CURRENCY’)tab2,
  4   (select VALUE$ cc from sys.props$ where name=’NLS_CHARACTERSET’)tab3;

TAB1.AA||’_’||TAB2.BB||’.’||TAB3.CC
———————————————————————-
AMERICAN_AMERICA.AL32UTF8
原因:由于源和目标数据库的字符集不一致或不是子集和超集的关系,所以造成不能导入表空间的字符集。
解决方法:将源数据库和目标数据库的字符集调整为一致的字符集;或者源数据库的字符集是目标数据库的子集。
源数据库的修改:
SQL> alter database character set internal_use utf8;
alter database character set internal_use utf8
*
第1行出现错误:
ORA-12719:操作要求数据库处于RESTRICTED模式下

SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
Oracle例程已经关闭。

SQL> startup mount;
Oracle例程已启动

Total System Global Area  444596224 bytes
Fixed Size                  1219904 bytes
Variable Size             138412736 bytes
Database Buffers          301989888 bytes
Redo Buffers                2973696 bytes
数据库已装载

SQL>  alter system enable restricted session;
系统已更改

SQL> alter database open;
数据库已更改

SQL> alter database character set internal_use utf8;
数据库已更改

SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
Oracle例程已经关闭。
SQL> startup mount;
Oracle例程已启动

Total System Global Area  444596224 bytes
Fixed Size                  1219904 bytes
Variable Size             138412736 bytes
Database Buffers          301989888 bytes
Redo Buffers                2973696 bytes
数据库已装载

SQL>  alter system disable restricted session;
系统已更改

SQL> alter database open; 
数据库已更改

SQL> select tab1.aa||’_’||tab2.bb||’.’||tab3.cc from
  2   (select VALUE$ aa from sys.props$ where name=’NLS_LANGUAGE’)tab1,
  3   (select VALUE$ bb from sys.props$ where name=’NLS_ISO_CURRENCY’)tab2,
  4   (select VALUE$ cc from sys.props$ where name=’NLS_CHARACTERSET’)tab3;

TAB1.AA||’_’||TAB2.BB||’.’||TAB3.CC
———————————————————————-
AMERICAN_AMERICA.UTF8
目标数据库修改:
SQL> alter database character set internal_use utf8;
alter database character set internal_use utf8
*
ERROR at line 1:
ORA-12719: operation requires database is in RESTRICTED mode

SQL> shutdown immediate;
Database closed.
Database dismounted.
Oracle instance shut down.

SQL> startup mount;
Oracle instance started.

Total System Global Area  444596224 bytes
Fixed Size                  1219904 bytes
Variable Size             138412736 bytes
Database Buffers          301989888 bytes
Redo Buffers                2973696 bytes
Database mounted.

SQL>  alter system enable restricted session;
System altered.

SQL> alter database open;
Database altered.

SQL> alter database character set internal_use utf8;
Database altered.

SQL> shutdown immediate;
Database closed.
Database dismounted.
Oracle instance shut down.

SQL> startup mount;
Oracle instance started.

Total System Global Area  444596224 bytes
Fixed Size                  1219904 bytes
Variable Size             138412736 bytes
Database Buffers          301989888 bytes
Redo Buffers                2973696 bytes
Database mounted.

SQL>  alter system disable restricted session;
System altered.

SQL> alter database open; 
Database altered.

SQL> select tab1.aa||’_’||tab2.bb||’.’||tab3.cc from
  2   (select VALUE$ aa from sys.props$ where name=’NLS_LANGUAGE’)tab1,
  3   (select VALUE$ bb from sys.props$ where name=’NLS_ISO_CURRENCY’)tab2,
  4   (select VALUE$ cc from sys.props$ where name=’NLS_CHARACTERSET’)tab3;

TAB1.AA||’_’||TAB2.BB||’.’||TAB3.CC
———————————————————————-
AMERICAN_AMERICA.UTF8
修改完成,再重新导出/导入一遍,即可成功。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1701879.html

(0)
上一篇 2025年2月19日 14:47:57
下一篇 2025年2月19日 14:48:13

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Navicat工具的多数据库连接和批量执行SQL语句的方法

    navicat支持多数据库连接和批量执行sql语句。1)多数据库连接允许同时管理多个数据库实例,提高工作效率。2)批量执行sql语句可在一次操作中执行多个命令,适用于数据迁移等场景,提升操作效率。 引言 在数据管理和开发的日常工作中,Nav…

    2025年4月28日
    000
  • RazorSQL工具的高级功能和SQL语句执行优化

    razorsql的高级功能包括sql查询分析器、数据库对象管理和数据导入导出。优化sql语句执行的技巧有:1. 使用索引;2. 避免全表扫描;3. 使用explain命令查看执行计划。 引言 RazorSQL作为一个功能强大的数据库管理和S…

    2025年4月28日
    000
  • DataGrip工具的数据库管理和SQL开发优势

    datagrip提供了强大且直观的数据库管理和sql开发功能,提升了工作效率。1)数据库管理方面,datagrip支持多种数据库,提供图形化界面,简化了操作。2)sql开发方面,datagrip提供了智能代码补全、语法高亮和调试功能,提升了…

    2025年4月28日
    000
  • SQLDeveloper工具在Oracle数据库中的应用和操作

    sqldeveloper在oracle数据库中的作用是提供一个集成的开发环境(ide),用于管理和操作数据库。其主要功能包括:1.执行sql查询和脚本,2.创建、修改和删除数据库对象,3.调试pl/sql代码,4.数据建模和数据库设计,5.…

    2025年4月28日
    000
  • DbVisualizer工具的数据库连接和SQL执行性能优化

    要优化dbvisualizer的数据库连接和sql执行性能,需采取以下措施:1. 配置连接池,设置最大和最小连接数。2. 设置合理的连接超时时间。3. 合理使用索引,避免全表扫描。4. 通过执行计划分析和调整查询语句来优化sql查询。 引言…

    2025年4月28日
    000
  • AquaDataStudio工具的SQL开发和数据库管理功能

    aquadatastudio支持多种数据库系统,并提供sql开发和数据库管理功能。1. sql开发:它提供语法高亮、自动完成和代码折叠,帮助编写sql查询。2. 数据库管理:通过图形化界面设计和管理数据库结构,支持数据备份和性能优化。 引言…

    2025年4月28日
    000
  • SQLPowerArchitect工具的数据库设计和SQL脚本生成

    sqlpowerarchitect可用于数据库设计和sql脚本生成。1)创建表和定义字段、关系。2)生成sql脚本用于数据库创建。3)支持逆向工程,优化现有数据库结构。 引言 在数据库设计和管理中,SQLPowerArchitect是一款非…

    2025年4月28日
    000
  • 开发微信小程序前需要做哪些准备工作

    开发微信小程序前的准备工作包括:1.注册微信开发者账号,2.配置开发环境,3.学习小程序的基本结构。注册账号需准备相关证件,配置环境需下载微信开发者工具,学习结构有助于快速上手开发。 引言 在开始开发微信小程序之前,你可能会问自己:我需要做…

    2025年4月28日
    000
  • 小程序开发语言学什么?

    小程序开发涉及哪些编程语言和框架呢?让我们来探讨一下开发一款微信小程序所需的前端开发语言、后端开发语言、数据库语言以及所使用的开发框架。以下是小程序开发所需掌握的基础知识: 一、小程序开发所使用的语言是什么? 1、前端开发语言 前端开发通常…

    2025年4月28日
    000
  • php7怎么连接数据库

    使用 PHP 7 连接数据库需要使用 PDO 类,步骤包括:创建一个 PDO 对象,指定服务器名、数据库名、用户名和密码。设置错误模式,以便抛出异常来处理错误。准备和执行查询。获取查询结果。 PHP 7 连接数据库 如何连接数据库? 在 P…

    2025年4月28日
    000

发表回复

登录后才能评论