Oracle 跨平台迁移——筑梦之路

oralce表空间跨平台跨版本迁移满足的前提条件:

1.源和目标数据库使用相同字节顺序(也就是说little endian与big engian)
2.目标数据库不能有和源库有相同的表空间
3.源和目标数据库拥有相同的块大小
4.必须传输自包含的对象集(我的理解是表空间内的对象不能跨表空间)

数据库版本:oralce 11g

#查询数据库版本信息
select * from v$version;

#查询数据库实例编码格式
SELECT
	userenv ( 'language' ) 
FROM
	dual;

#查询支持的平台
SELECT
	* 
FROM
	V$TRANSPORTABLE_PLATFORM;

#检查字节顺序
select d.platform_name,endian_format
from v$transportable_platform tp,v$database d
where tp.platform_name=d.platform_name;

#查询表空间名称及大小
SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size 
FROM dba_tablespaces t, dba_data_files d 
WHERE t.tablespace_name = d.tablespace_name 
GROUP BY t.tablespace_name;

#查询表空间物理文件名称及大小
SELECT tablespace_name, 
file_id, 
file_name, 
round(bytes / (1024 * 1024), 0) total_space 
FROM dba_data_files 
ORDER BY tablespace_name;

#查询回滚段名称及大小
SELECT segment_name, 
tablespace_name, 
r.status, 
(initial_extent / 1024) initialextent, 
(next_extent / 1024) nextextent, 
max_extents, 
v.curext curextent 
FROM dba_rollback_segs r, v$rollstat v 
WHERE r.segment_id = v.usn(+) 
ORDER BY segment_name;

#查询控制文件
SELECT NAME FROM v$controlfile; 

#查询日志文件
SELECT MEMBER FROM v$logfile;

#查询表空间使用情况
SELECT SUM(bytes) / (1024 * 1024) AS free_space, tablespace_name 
FROM dba_free_space 
GROUP BY tablespace_name; 

SELECT a.tablespace_name, 
a.bytes total, 
b.bytes used, 
c.bytes free, 
(b.bytes * 100) / a.bytes "% USED ", 
(c.bytes * 100) / a.bytes "% FREE " 
FROM sys.sm$ts_avail a, sys.sm$ts_used b, sys.sm$ts_free c 
WHERE a.tablespace_name = b.tablespace_name 
AND a.tablespace_name = c.tablespace_name; 

#查询数据库库对象
SELECT owner, object_type, status, COUNT(*) count# 
FROM all_objects 
GROUP BY owner, object_type, status; 

#查询数据库版本
SELECT version 
FROM product_component_version 
WHERE substr(product, 1, 6) = 'Oracle'; 

#查询数据库创建日期和归档方式
SELECT created, log_mode, log_mode FROM v$database;

#友好的显示方式
SELECT a.tablespace_name "表空间名", 
total "表空间大小", 
free "表空间剩余大小", 
(total - free) "表空间使用大小", 
total / (1024 * 1024 * 1024) "表空间大小(G)", 
free / (1024 * 1024 * 1024) "表空间剩余大小(G)", 
(total - free) / (1024 * 1024 * 1024) "表空间使用大小(G)", 
round((total - free) / total, 4) * 100 "使用率 %" 
FROM (SELECT tablespace_name, SUM(bytes) free 
FROM dba_free_space 
GROUP BY tablespace_name) a, 
(SELECT tablespace_name, SUM(bytes) total 
FROM dba_data_files 
GROUP BY tablespace_name) b 
WHERE a.tablespace_name = b.tablespace_name;

--1G=1024MB 
--1M=1024KB 
--1K=1024Bytes 
--1M=11048576Bytes 
--1G=1024*11048576Bytes=11313741824Bytes 

#查询管理员目录
select * from dba_directories;
数据泵方式

exp/imp与expdp/impdp的区别:

1、exp和imp是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用。
2、expdp和impdp是服务端的工具程序,他们只能在Oracle服务端使用,不能在客户端使用。
3、imp只适用于exp导出的文件,不适用于expdp导出文件;impdp只适用于expdp导出的文件,而不适用于exp导出文件。
4、对于10g以上的服务器,使用exp通常不能导出0行数据的空表,而此时必须使用expdp导出。

expdp参数说明:

#关键字

ATTACH                连接到现有作业, 例如 ATTACH [=作业名]。

 COMPRESSION               减小转储文件内容的大小, 其中有效关键字  值为: ALL, (METADATA_ONLY), DATA_ONLY 和 NONE。

 CONTENT                指定要卸载的数据, 其中有效关键字  值为: (ALL), DATA_ONLY 和 METADATA_ONLY。

 DATA_OPTIONS             数据层标记, 其中唯一有效的值为: 使用CLOB格式的 XML_CLOBS-write XML 数据类型。

 DIRECTORY               供转储文件和日志文件使用的目录对象,即逻辑目录。

 DUMPFILE               目标转储文件 (expdp.dmp) 的列表,例如 DUMPFILE=expdp1.dmp, expdp2.dmp。

 ENCRYPTION               加密部分或全部转储文件, 其中有效关键字值为: ALL, DATA_ONLY, METADATA_ONLY,ENCRYPTED_COLUMNS_ONLY 或 NONE。

 ENCRYPTION_ALGORITHM        指定应如何完成加密, 其中有效关键字值为: (AES128), AES192 和 AES256。

 ENCRYPTION_MODE           生成加密密钥的方法, 其中有效关键字值为: DUAL, PASSWORD 和 (TRANSPARENT)。

 ENCRYPTION_PASSWORD         用于创建加密列数据的口令关键字。

 ESTIMATE               计算作业估计值, 其中有效关键字值为: (BLOCKS) 和 STATISTICS。

 ESTIMATE_ONLY            在不执行导出的情况下计算作业估计值。

 EXCLUDE                排除特定的对象类型, 例如 EXCLUDE=TABLE:EMP。例:EXCLUDE=[object_type]:[name_clause],[object_type]:[name_clause] 。

 FILESIZE               以字节为单位指定每个转储文件的大小。

 FLASHBACK_SCN            用于将会话快照设置回以前状态的 SCN。 -- 指定导出特定SCN时刻的表数据。

 FLASHBACK_TIME           用于获取最接近指定时间的 SCN 的时间。-- 定导出特定时间点的表数据,注意FLASHBACK_SCN和FLASHBACK_TIME不能同时使用。

  FULL                  导出整个数据库 (N)。  

 HELP                  显示帮助消息 (N)。

 INCLUDE                包括特定的对象类型, 例如 INCLUDE=TABLE_DATA。

 JOB_NAME                 要创建的导出作业的名称。

 LOGFILE                日志文件名 (export.log)。

 NETWORK_LINK             链接到源系统的远程数据库的名称。

 NOLOGFILE              不写入日志文件 (N)。
 
 PARALLEL                更改当前作业的活动 worker 的数目。

 PARFILE                指定参数文件。

 QUERY                  用于导出表的子集的谓词子句。--QUERY = [schema.][table_name:] query_clause。

 REMAP_DATA               指定数据转换函数,例如 REMAP_DATA=EMP.EMPNO:REMAPPKG.EMPNO。

 REUSE_DUMPFILES           覆盖目标转储文件 (如果文件存在) (N)。

 SAMPLE                  要导出的数据的百分比。

 SCHEMAS                要导出的方案的列表 (登录方案)。  

 STATUS                 在默认值 (0) 将显示可用时的新状态的情况下,要监视的频率 (以秒计) 作业状态。  
 
 TABLES                 标识要导出的表的列表 - 只有一个方案。--[schema_name.]table_name[:partition_name][,…]

 TABLESPACES              标识要导出的表空间的列表。

 TRANSPORTABLE             指定是否可以使用可传输方法, 其中有效关键字值为: ALWAYS, (NEVER)。

 TRANSPORT_FULL_CHECK         验证所有表的存储段 (N)。 

 TRANSPORT_TABLESPACES         要从中卸载元数据的表空间的列表。

 VERSION                要导出的对象的版本, 其中有效关键字为:(COMPATIBLE), LATEST 或任何有效的数据库版本。

#命令
ADD_FILE               向转储文件集中添加转储文件。

 CONTINUE_CLIENT           返回到记录模式。如果处于空闲状态, 将重新启动作业。

 EXIT_CLIENT             退出客户机会话并使作业处于运行状态。

 FILESIZE               后续 ADD_FILE 命令的默认文件大小 (字节)。

 HELP                 总结交互命令。

 KILL_JOB               分离和删除作业。

 PARALLEL                更改当前作业的活动 worker 的数目。PARALLEL=<worker 的数目>。

 _DUMPFILES               覆盖目标转储文件 (如果文件存在) (N)。

 START_JOB                启动/恢复当前作业。

 STATUS                 在默认值 (0) 将显示可用时的新状态的情况下,要监视的频率 (以秒计) 作业状态。STATUS[=interval]。

 STOP_JOB                顺序关闭执行的作业并退出客户机。STOP_JOB=IMMEDIATE 将立即关闭数据泵作业。

impdp 参数说明:
#关键字
ATTACH                         连接到现有作业, 例如 ATTACH [=作业名]。

CONTENT                     指定要卸载的数据, 其中有效关键字  值为: (ALL), DATA_ONLY 和 METADATA_ONLY。

DATA_OPTIONS                  数据层标记,其中唯一有效的值为:SKIP_CONSTRAINT_ERRORS-约束条件错误不严重。

DIRECTORY                  供转储文件,日志文件和sql文件使用的目录对象,即逻辑目录。

DUMPFILE                   要从(expdp.dmp)中导入的转储文件的列表,例如 DUMPFILE=expdp1.dmp, expdp2.dmp。

 ENCRYPTION_PASSWORD            用于访问加密列数据的口令关键字。此参数对网络导入作业无效。

 ESTIMATE                  计算作业估计值, 其中有效关键字为:(BLOCKS)和STATISTICS。

 EXCLUDE                   排除特定的对象类型, 例如 EXCLUDE=TABLE:EMP。

 FLASHBACK_SCN               用于将会话快照设置回以前状态的 SCN。

 FLASHBACK_TIME               用于获取最接近指定时间的 SCN 的时间。

 FULL                     从源导入全部对象(Y)。
  
 HELP                     显示帮助消息(N)。

 INCLUDE                   包括特定的对象类型, 例如 INCLUDE=TABLE_DATA。

 JOB_NAME                   要创建的导入作业的名称。

 LOGFILE                    日志文件名(import.log)。

 NETWORK_LINK                链接到源系统的远程数据库的名称。

 NOLOGFILE                  不写入日志文件。  

 PARALLEL                    更改当前作业的活动worker的数目。

 PARFILE                    指定参数文件。

 PARTITION_OPTIONS               指定应如何转换分区,其中有效关键字为:DEPARTITION,MERGE和(NONE)。

 QUERY                     用于导入表的子集的谓词子句。

 REMAP_DATA                  指定数据转换函数,例如REMAP_DATA=EMP.EMPNO:REMAPPKG.EMPNO。

 REMAP_DATAFILE                在所有DDL语句中重新定义数据文件引用。

 REMAP_SCHEMA                 将一个方案中的对象加载到另一个方案。

 REMAP_TABLE                  表名重新映射到另一个表,例如 REMAP_TABLE=EMP.EMPNO:REMAPPKG.EMPNO。

 REMAP_TABLESPACE               将表空间对象重新映射到另一个表空间。

 REUSE_DATAFILES               如果表空间已存在, 则将其初始化 (N)。

 SCHEMAS                   要导入的方案的列表。

 SKIP_UNUSABLE_INDEXES            跳过设置为无用索引状态的索引。

 SQLFILE                   将所有的 SQL DDL 写入指定的文件。

 STATUS                    在默认值(0)将显示可用时的新状态的情况下,要监视的频率(以秒计)作业状态。  

 STREAMS_CONFIGURATION            启用流元数据的加载。

 TABLE_EXISTS_ACTION            导入对象已存在时执行的操作。有效关键字:(SKIP),APPEND,REPLACE和TRUNCATE。

 TABLES                     标识要导入的表的列表。

 TABLESPACES                  标识要导入的表空间的列表。 

 TRANSFORM                   要应用于适用对象的元数据转换。有效转换关键字为:SEGMENT_ATTRIBUTES,STORAGE,OID和PCTSPACE。

 TRANSPORTABLE                 用于选择可传输数据移动的选项。有效关键字为: ALWAYS 和 (NEVER)。仅在 NETWORK_LINK 模式导入操作中有效。

 TRANSPORT_DATAFILES             按可传输模式导入的数据文件的列表。

 TRANSPORT_FULL_CHECK            验证所有表的存储段 (N)。

 TRANSPORT_TABLESPACES            要从中加载元数据的表空间的列表。仅在 NETWORK_LINK 模式导入操作中有效。

  VERSION                    要导出的对象的版本, 其中有效关键字为:(COMPATIBLE), LATEST 或任何有效的数据库版本。仅对 NETWORK_LINK 和 SQLFILE 有效。

#命令
CONTINUE_CLIENT          返回到记录模式。如果处于空闲状态, 将重新启动作业。

 EXIT_CLIENT            退出客户机会话并使作业处于运行状态。

 HELP                 总结交互命令。

 KILL_JOB              分离和删除作业。

 PARALLEL              更改当前作业的活动 worker 的数目。PARALLEL=<worker 的数目>。

 START_JOB              启动/恢复当前作业。START_JOB=SKIP_CURRENT 在开始作业之前将跳过作业停止时执行的任意操作。

 STATUS               在默认值 (0) 将显示可用时的新状态的情况下,要监视的频率 (以秒计) 作业状态。STATUS[=interval]。

 STOP_JOB              顺序关闭执行的作业并退出客户机。STOP_JOB=IMMEDIATE 将立即关闭数据泵作业。


准备工作:
若有必要,需要在新库上建立必要的表空间、用户(并赋权)、数据备份目录,源库上创建数据备份目录等。

#新的数据库上操作:

--创建临时表空间
create temporary tablespace 用户临时表空间名称 
tempfile '/u01/tablespaces/user_temp.dbf' 
size 50m 
autoextend on 
next 50m maxsize 20480m 
extent management local;

备注:根据实际情况调整表空间大小等参数以及规划临时表空间、回滚表空间等相关规划。

--创建数据表空间
create tablespace 用户表空间名称 
datafile '/u01/tablespaces/user_data.dbf' 
size 50m 
autoextend on 
next 50m maxsize 20480m 
extent management local;

--建立用户,并指定默认表空间
create user 用户名称 identified by 密码 
default tablespace 用户表空间名称 
temporary tablespace 用户临时表空间名称;

--给用户授权
grant connect,resource to 用户名1;
grant create database link to 用户名;

注意:赋权给多个用户的情况下,各个用户名称间用,分隔即可。

--登录需要创建dblink的用户,创建dblink
CREATE DATABASE LINK DBLink名称 
CONNECT TO 用户 IDENTIFIED BY 密码 
USING '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS =(PROTOCOL = TCP)(HOST = XXX.XXX.XXX.XXX)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = 实例名)))';

注意:创建DBLINK默认是用户级别的,对当前用户有效。只有当需要对所有用户有效时,再建立公有的DBlink对象(pulic参数)。

关于DBlink的知识点,参考:Oracle--dblink使用  http://www.cnblogs.com/chinas/p/6973058.html

创建数据备份目录(源库和目标库)

备份目录需要使用操作系统用户创建一个真实的目录,然后登录oracle dba用户,创建逻辑目录,指向该路径。这样oracle才能识别这个备份目录。

#创建物理目录
mkdir -p /u01/app/oracle/bankup
#oracle登陆
sqlplus /nolog
SQL> conn /as sysdba

#创建逻辑目录
SQL> create directory auto_bankup as '/u01/app/oracle/bankup';

#检查目录是否创建成功
SQL> select * from dba_directories;

#用sys管理员给指定用户赋予在该目录的操作权限
SQL> grant read,write on directory data_dir to user;
SQL> grant read,write on directory data_dir to user1,user2;

导出导入命令示例:
1.expdp导出
确保已经创建数据备份路径,若没有则按照准备工作中的说明进行创建。(注意:若CPU资源充足强烈推荐开启并行参数,可以大大节省导入、导出的时间)

#全量导出 full=y
expdp user/passwd@orcl dumpfile=expdp.dmp directory=data_dir full=y logfile=expdp.log;

#按用户导出 schemas=user
expdp user/passwd@orcl schemas=user dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

#按表空间导出 tablespace
expdp sys/passwd@orcl tablespace=tbs1,tbs2 dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

#导出指定表
expdp user/passwd@orcl tables=table1,table2 dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;

#按查询条件导出
expdp user/passwd@orcl tables=table1='where number=1234' dumpfile=expdp.dmp directory=data_dir logfile=expdp.log;


2.impdp导入
注意:

  (1)确保数据库软件安装正确,字符集、数据库版本等与源库一致,尽量此类因素引起的失败。

  (2)确保数据库备份目录已提前建好,若没有,参考前面的说明建立该目录。

  (3)提前将源库导出的数据文件传递到目标库的备份目录下,并确保导入时的数据库用户对该文件有操作权限。

#全量导入
impdp user/passwd directory=data_dir dumpfile=expdp.dmp full=y;

#同名用户导入,从用户A导入到用户A
impdp A/passwd schemas=A directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

#第三种方式
a.从A用户中把表table1和table2导入到B用户中
impdp B/passwdtables=A.table1,A.table2 remap_schema=A:B directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

b.将表空间TBS01、TBS02、TBS03导入到表空间A_TBS,将用户B的数据导入到A,并生成新的oid防止冲突;

impdp A/passwdremap_tablespace=TBS01:A_TBS,TBS02:A_TBS,TBS03:A_TBS remap_schema=B:A FULL=Y transform=oid:n 
directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

#第四种方式 导入表空间
impdp sys/passwd tablespaces=tbs1 directory=data_dir dumpfile=expdp.dmp logfile=impdp.log;

#第五种方式 数据追加
impdp sys/passwd directory=data_dir dumpfile=expdp.dmp schemas=system table_exists_action=replace logfile=impdp.log; 

--table_exists_action:导入对象已存在时执行的操作。有效关键字:SKIP,APPEND,REPLACE和TRUNCATE

未完待续

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值