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:指定导入的表空间集合中包含对象的用户名。这个参数可以不指定,如果指定则必须保证正确性。
FROMUSER和TOUSER:如果不指定这两个参数,则导入的时候会根据表空间集合中对象的原始用户名导入,如果用户名在目标数据库不存在,则会报错。可以通过指定FROMUSER和TOUSER来改变对象的属主。
执行完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;
表空间已更改。