yangtingkun
===========================================================
传输表空间
===========================================================

Oracle的传输表空间是指,可以将一个数据库上的一个或多个表空间的全表数据文件拷贝到另一个数据库服务器上,通过导入的方式将表空间加载当目标数据库。

使用这种方法的最大好处是速度快,所需要的时间和拷贝数据文件差不多,比执行EXP/IMP的导入导出要快得多。

传输表空间的限制条件:

源和目标数据库必须处于相同的平台,在10g中,这条约束被放宽了;

源和目标数据库必须使用相同的字符集和国家字符集;

目标数据库不能已经包含同名的表空间;

传输表空间不支持:物化视图或复制、基于函数的索引、Scoped REFs和兼容性设置为8.0时,带有多个收件人的高级队列。

使用传输表空间应该使源和目标数据库的兼容性都在8.1以上,如果源数据库中的表空间的block_size和目标数据库的db_block_size不相等,那么目标数据库的兼容性必须设置为9.0以上。

使用传输表空间的步骤:

1.验证表空间是否是自包含的,被传输的表空间必须是自包含的。自包含的含义是在被传输的表空间集合里的所有对象,不会参考到这个集合以外的其它对象。下面列出的是违反自包含条件的几种最常见的情况。

索引在这个表空间集合内,但是索引指向的表在集合之外;

分区表的部分分区在集合之外;

完整性约束的参考对象在集合之外;

表中包含的LOB对象存储在集合之外。

Oracle提供了过程dbms_tts.transport_set_check来检查一个表空间集合是否是自包含的。这个过程有三个参数,第一个是表空间名字的列表,用逗号分隔,第二个参数指出是否检查完整性约束,第三个参数指出检查集合内参考集合外的同时是否反过来检查集合外是否参考了集合内的对象。

执行完过程后,查询视图TRANSPORT_SET_VIOLATIONS查看检查结果。解决视图中给出的错误后,就完成了第一步。

2.产生传输表空间集合

首先将所有要传输的表空间置为READ ONLY

使用EXP导出所需的数据字典信息。

使用EXP的时候必须以SYSDBA身份登陆。

在导出的时候可以指定是否导出触发器、完整性约束和权限。

3.传输表空间集合

将表空间包含的所有数据文件以及EXP得到的dmp文件通过操作系统级的命令拷贝到目标数据库服务器的指定目录。

在所有导出表空间的数据文件已经拷贝到指定地点后,可以将所有表空间设置为READ WRITE

4.导入表空间集合

SYSDBA身份使用IMP导入表空间集合。

IMP的时候注意以下几个参数:

TABLESPACES:指定导入的表空间集合名称。这个参数可以不指定,如果指定则必须和导入的表空间名称一致。

TTS_OWNERS:指定导入的表空间集合中包含对象的用户名。这个参数可以不指定,如果指定则必须保证正确性。

FROMUSERTOUSER:如果不指定这两个参数,则导入的时候会根据表空间集合中对象的原始用户名导入,如果用户名在目标数据库不存在,则会报错。可以通过指定FROMUSERTOUSER来改变对象的属主。

执行完IMP操作后,如果有必要,可以将表空间置为READ WRITE


下面是一个简单的小例子:

SQL> EXEC SYS.DBMS_TTS.TRANSPORT_SET_CHECK('TEST', TRUE);

PL/SQL 过程已成功完成。

SQL> SELECT * FROM SYS.TRANSPORT_SET_VIOLATIONS;

VIOLATIONS
----------------------------------------------------------------
Index YANGTK.IND_T_NAME in tablespace TEST points to table YANGTK.T in tablespace YANGTK

SQL> ALTER INDEX IND_T_NAME REBUILD TABLESPACE YANGTK;

索引已更改。

SQL> EXEC SYS.DBMS_TTS.TRANSPORT_SET_CHECK('TEST', TRUE);

PL/SQL 过程已成功完成。

SQL> SELECT * FROM SYS.TRANSPORT_SET_VIOLATIONS;

未选定行

SQL> ALTER TABLESPACE TEST READ ONLY;

表空间已更改。

E:>exp """/@test as sysdba""" file=trans.dmp transport_tablespace=y tablespaces=test triggers=n constraints=y grants=y

Export: Release 9.2.0.1.0 - Production on 星期四 1 13 16:47:24 2005

Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.

连接到: Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production

With the Partitioning, Oracle Label Security, OLAP and Oracle Data Mining options

JServer Release 9.2.0.1.0 - Production

已导出 ZHS16GBK 字符集和 AL16UTF16 NCHAR 字符集

: 将不会导出表数据(行)

关于导出可传输的表空间元数据...

用于表空间 TEST...

. 正在导出群集定义

. 正在导出表定义

. . 正在导出表 TEST

. 正在导出引用完整性约束条件

. 结束导出可传输的表空间元数据

在没有警告的情况下成功终止导出。

E:>copy e:oracleoradatatesttest.dbf e:oracleoradatayangtktest.dbf

已复制 1 个文件。

SQL> ALTER TABLESPACE TEST READ WRITE;

表空间已更改。

E:>imp """/@yangtk as sysdba""" file=trans.dmp transport_tablespace=y datafiles='e:oracleoradatayangtktest.dbf' tablespaces=test tts_owners=yangtk

Import: Release 9.2.0.1.0 - Production on 星期四 1 13 16:53:26 2005

Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.

连接到: Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production

With the Partitioning, Oracle Label Security, OLAP and Oracle Data Mining options

JServer Release 9.2.0.1.0 - Production

经由常规路径导出由EXPORT:V09.02.00创建的文件

关于导入可传输表空间元数据...

已经完成ZHS16GBK字符集和AL16UTF16 NCHAR 字符集中的导入

. 正在将SYS的对象导入到 SYS

. 正在将YANGTK的对象导入到 YANGTK

. . 正在导入表 "TEST"

成功终止导入,但出现警告。

SQL> CONN YANGTK/YANGTK@YANGTK已连接。
SQL> ALTER TABLESPACE TEST READ WRITE;

表空间已更改。

yangtingkun 发表于:2005.01.13 16:59 ::分类: ( ORACLE ) ::阅读:(8645次) :: 评论 (13)
[回复]

在导出了表空间的元数据定义以后就可以将源数据库表空间置为read/write?
如果在传输表空间相关数据文件的过程中有人修改了表空间的内容,不会有问题么?

应该是在数据文件传输结束后再将表空间置为read/write吧?

echo 评论于: 2006.05.13 18:56
你说的没错 [回复]

这篇文章写的比较早,当时对传输表空间理解的还不是很清楚。

表空间设置为只读就是为了保证数据的一致性,因此只有讲表空间的数据文件拷贝完成之后才能在源数据库恢复表空间的可读写状态。

否则,在目标数据库导入的时候就会出现下列错误:
IMP-00017: following statement failed with ORACLE error 19722:
"BEGIN sys.dbms_plugts.checkDatafile(NULL,2477020614,8,12800,8,8,0,0,13614"
"8,2980693211,1,33554434,NULL,NULL,NULL); END;"
IMP-00003: ORACLE error 19722 encountered
ORA-19722: datafile /data/oradata/member/log.dbf is an incorrect version
ORA-06512: at "SYS.DBMS_PLUGTS", line 1730
ORA-06512: at line 1
IMP-00000: Import terminated unsuccessfully

文章中错误的地方我已经修改,感谢你指出

yangtingkun 评论于: 2006.05.15 10:30
嗯! [回复]

刚好最近在学习这部份内容

关注你的文章中:)

echo 评论于: 2006.05.16 11:40
我已经read only了,可还错 [回复]

Export file created by EXPORT:V10.02.01 via conventional path
About to import transportable tablespace(s) metadata...
import done in ZHS16GBK character set and AL16UTF16 NCHAR character set
. importing SYS's objects into SYS
. importing SYS's objects into SYS
IMP-00017: following statement failed with ORACLE error 19721:
"BEGIN sys.dbms_plugts.checkDatafile(NULL,461331545,5,1280,4,5,0,0,225712,"
"226300,1,20971522,NULL,NULL,NULL); END;"
IMP-00003: ORACLE error 19721 encountered
ORA-19721: Cannot find datafile with absolute file number 5 in tablespace TSTS
ORA-06512: at "SYS.DBMS_PLUGTS", line 2065
ORA-06512: at line 1
IMP-00000: Import terminated unsuccessfully
$

l1t 评论于: 2006.06.15 16:49
我已经read only了,可还错 [回复]

Export file created by EXPORT:V10.02.01 via conventional path
About to import transportable tablespace(s) metadata...
import done in ZHS16GBK character set and AL16UTF16 NCHAR character set
. importing SYS's objects into SYS
. importing SYS's objects into SYS
IMP-00017: following statement failed with ORACLE error 19721:
"BEGIN sys.dbms_plugts.checkDatafile(NULL,461331545,5,1280,4,5,0,0,225712,"
"226300,1,20971522,NULL,NULL,NULL); END;"
IMP-00003: ORACLE error 19721 encountered
ORA-19721: Cannot find datafile with absolute file number 5 in tablespace TSTS
ORA-06512: at "SYS.DBMS_PLUGTS", line 2065
ORA-06512: at line 1
IMP-00000: Import terminated unsuccessfully
$

l1t 评论于: 2006.06.15 16:50
文件是存在的 [回复]

imp userid='sys/sys as sysdba' tablespaces=tsts file=/tmp/tsts.dmp log=/tmp/tsts.dmp.imp.log transport_tablespace=y datafiles=/oracle/TSTS01.DBF, /oracle/TSTS01.DBF
$ ls -l /oracle
total 2702844
-rw-r----- 1 oracle oinstall 10493952 Jun 15 16:30 TSTS01.DBF
-rw-r----- 1 oracle oinstall 10493952 Jun 15 16:30 TSTS02.DBF

l1t 评论于: 2006.06.15 16:54
re: 传输表空间 [回复]

这里不方便,去论坛发贴吧

yangtingkun 评论于: 2006.06.15 23:31
re: 传输表空间 [回复]

表空间下有多个数据库文件时能否同时传输多个表空间?
测试环境:
我把表建在表空间DATA中,索引指定为IND表空间中,我使用自包含同时检测这两个表空间时无结果.但在使用
IMP """/ AS SYSDBA""" FILE=TRANS.DMP TRANSPORT_TABLESPACE=Y DATAFILES=('E:TB1.DBF','E:IND1.DBF') TABLESPACE=(DATA,IND)
导入的时候在创建表定义时提示无效的SQL语句.
导入前是否还少了什么步骤?是否在新的数据库里先要创建用户和表空间吗?

快速导入 评论于: 2006.07.11 04:28
re: 传输表空间 [回复]

用户必须存在,表空间一定不能存在

yangtingkun 评论于: 2006.07.11 08:22
re: 传输表空间 [回复]

exp """/@test as sysdba"""
这边2对3个双引号是什么意思咯?

echo 评论于: 2006.07.23 14:34
re: 传输表空间 [回复]

引号的作用是将/@YANGTK AS SYSDBA作为一个整体提交给Oracle,其他的引号是转义符

yangtingkun 评论于: 2006.07.23 17:22
re: 传输表空间 [回复]

看了你的老文档做,就报了这个错!laughing

dk.fung 评论于: 2010.01.21 11:41
re: 传输表空间 [回复]

这个文档是几年前在9.2下的例子,建议你看看最新的数据泵或PL/SQL执行表空间迁移的例子。

如果是9.2环境,那么不妨把出错语句和错误信息贴出来

yangtingkun 评论于: 2010.01.21 22:01

发表评论
标题

在此添加评论
表情符号: smile laughing tongue angry crying sad wassat wink

称呼

邮箱地址(可选)

个人主页(可选)

 authimage


切换风格
新闻聚合
博客日历
文章归档...
最新发表...
最新评论...
最多阅读文章...
最多评论文章...
博客统计...
Blog信息
网站链接...