首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > Oracle的传输表空间简介
【标  题】:Oracle的传输表空间简介
【关键字】:Oracle
【来  源】:http://www.cublog.cn/u/7040/showart.php?id=140177

Oracle的传输表空间简介

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 个文件。

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;

表空间已更改。
事务处理:【上一篇】
Oracle Secure Backup在Linux下的安装:【下一篇】
【相关文章】
  • Oracle 9i数据库字符集全攻略
  • 改oracle9i的参数OPEN_LINKS
  • oracle常用管理命令
  • 修改Oracle XDB默认监听端口
  • oracle 简洁明了的常用命令
  • Oracle10g RAC with ocfs在windows安装 (转载)
  • oracle基本命令
  • 在CentOS4.3(x86_64)上安装Oracle9204 for linux(x86_64)
  • Oracle 9.2.0.4 on RHEL AS4
  • Oracle 8.1.7 on RedHat Linux 7.2
  • 【随机文章】
  • 《传奇》30道术道士的牛洞攻略
  • 3ds Max 5.0 新材质Ink 'n Paint Material介绍(2)
  • MFC漫谈(五)——消息的路由(2)
  • 从lex&yacc说到编译器
  • DNA与圆的结合
  • 开发者发行版: Elive 0.5.3 (不稳定版)
  • XP“写入缓存失败”的八个常见原因
  • 修改Linux的系统默认语言
  • 用SQL Server2005同义词链接Oracle的完整过程
  • 读书笔记(一,基础知识)
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.