• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Oracle 传输表空间

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

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

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

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

传输表空间的限制条件:

源和目标数据库必须使用相同的字符集和国家字符集(分别对应nls_database_parameters视图的NLS_CHARACTERSET与NLS_NCHAR_CHARACTERSET值)

如果要传输到其它os平台,compatible必须要设置为10.0以上。

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

执行完过程后,查询视图transport_set_violations查看检查结果 ,,如果为空,说明是自包含的,可以进行传输表空间。

实验:

–源端创建测试表空间与测试用户
SQL> create tablespace t_tbs datafile ‘G:\oracle\product\10.2.0\oradata\orcl\t_tbs01.dbf’
2 size 10M;

表空间已创本文来源gao($daima.com搞@代@#码$网建。

SQL> create user test identified by test;

用户已创建。

SQL> grant connect,resource to test;

授权成功。

SQL> conn test/test@orcl
已连接。
SQL> create table t_t (id int) tablespace t_tbs;

表已创建。

SQL> insert into t_t select level from dual connect by level<100;

已创建99行。

SQL> commit;

提交完成。

–1.源端检查自包含
SQL> show user
USER 为 “SYS”
SQL> execute dbms_tts.transport_set_check(‘t_tbs’,true);

PL/SQL 过程已成功完成。

SQL> select * from transport_set_violations;

未选定行

–2.源端在导出之前置表空间为只读
SQL> alter tablespace t_tbs read only;

表空间已更改。

–3.执行导出 ,需sysdba
SQL> ho exp ‘sys/oracle@orcl as sysdba’ transport_tablespace=y tablespaces=t_tbs file=d:t_tbs.dmp

Export: Release 10.2.0.1.0 – Production on 星期四 8月 30 22:16:12 2012

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

连接到: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 – Production
With the Partitioning, OLAP and Data Mining options
已导出 ZHS16GBK 字符集和 AL16UTF16 NCHAR 字符集
注: 将不导出表数据 (行)
即将导出可传输的表空间元数据…
对于表空间 T_TBS…
. 正在导出簇定义
. 正在导出表定义
. . 正在导出表 T_T
. 正在导出引用完整性约束条件
. 正在导出触发器
. 结束导出可传输的表空间元数据
成功终止导出, 没有出现警告。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Oracle 传输表空间

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址