传输表空间及问题处理(84天)

今天试验表空间传输,从一个库PROD 传输表空间到repos

假定表employees 在tbs4表空间里

SQL> select table_name,tablespace_name from user_tables where tablespace_name='TBS4';
TABLE_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
EMPLOYEES                      TBS4

当然employees 表里有一些constaints什么的。

表空间传输,可以用dbms_tts.transport_set_check('TBS4',TRUE);

然后用transport_set_violations来查询传输是否有可行。

发现有一些关联的constraint(外键等)的影响

spool 如下脚本

SQL> select 'alter table employees disable constraint '||constraint_name ||' CASCADE;' from user_constraints where table_name='EMPLOYEES';
'ALTERTABLEEMPLOYEESDISABLECONSTRAINT'||CONSTRAINT_NAME||'CASCADE;'
--------------------------------------------------------------------------------
alter table employees disable constraint EMP_LAST_NAME_NN CASCADE;
alter table employees disable constraint EMP_EMAIL_NN CASCADE;
alter table employees disable constraint EMP_HIRE_DATE_NN CASCADE;
alter table employees disable constraint EMP_JOB_NN CASCADE;
alter table employees disable constraint EMP_SALARY_MIN CASCADE;
alter table employees disable constraint EMP_EMAIL_UK CASCADE;
alter table employees disable constraint EMP_EMP_ID_PK CASCADE;
alter table employees disable constraint EMP_MANAGER_FK CASCADE;
alter table employees disable constraint EMP_JOB_FK CASCADE;
alter table employees disable constraint EMP_DEPT_FK CASCADE;
alter table employees disable constraint SYS_C003327 CASCADE;
'ALTERTABLEEMPLOYEESDISABLECONSTRAINT'||CONSTRAINT_NAME||'CASCADE;'
--------------------------------------------------------------------------------
alter table employees disable constraint SYS_C003328 CASCADE;
alter table employees disable constraint SYS_C003329 CASCADE;
13 rows selected.

运行就可以去除constraint的问题了。

检查没问题就可以传输了。

首先把tbs4置为只读状态

alter tablespace tbs4 read only;
exp \'sys/oracle@PROD as sysdba\' file=hr_PROD.dmp transport_tablespace=y
tablespaces=tbs4

导出源数据文件来

然后scp到目标库的机器上,数据文件tbs04.db也拷贝到对应的目录下

在目标库上运行

imp \'sys/oracle123@repos as sysdba\' file=hr_PROD.dmp transport_tablespace=y tablespaces=tbs4 datafiles=/u01/app/db/oradata/repos/tbs04.dbf

运行过后,似乎一切都ok了,新建一个分区表,结构和employees一模一样。

SQL> create table emp_part partition by range(hire_date)
(
PARTITION p1 VALUES LESS THAN(TO_DATE('01/01/1980','DD/MM/YYYY')) tablespace tbs1,
PARTITION p2 VALUES LESS THAN(TO_DATE('01/01/1990','DD/MM/YYYY')) tablespace tbs2,
PARTITION p3 VALUES LESS THAN(TO_DATE('01/01/2000','DD/MM/YYYY')) tablespace tbs3,
PARTITION p4 VALUES LESS THAN(TO_DATE('01/01/2010','DD/MM/YYYY')) tablespace tbs4,
PARTITION p5 VALUES LESS THAN(maxvalue) tablespace tbs1
)
as select * from employees where rownum<1;  2    3    4    5    6    7    8    9  
as select * from employees where rownum<1
                 *
ERROR at line 9:
ORA-28110: policy function or package HR.RLS_F has error

这个表中可能还有原来的函数

--检查一下是否存在

SQL> SELECT OBJECT_NAME FROM DBA_OBJECTS WHERE OBJECT_TYPE='FUNCTION' AND OBJECT_NAME ='RLS_F';
OBJECT_NAME
--------------------------------------------------------------------------------
RLS_F

--重新编译一下就可以了。

SQL> alter function HR.RLS_F compile;
Function altered.

最后一定记住把传输后的表空间置为read write.

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2014-05-26

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

Oracle大表清理truncate .. reuse storage

a、通过上述测试,当使用reuse storage与普通方式并无明显差异 b、truncate table 是ddl操作,无法回滚 c、尽管无明显性能差...

724
来自专栏idba

死锁案例之二

一 前言 死锁,其实是一个很有意思也很有挑战的技术问题,大概每个DBA都会在工作过程中遇见。关于死锁我会持续写一个系列的案例分析,希望能够对想了解死锁的朋友有...

755
来自专栏杨建荣的学习笔记

物化视图相关的性能改进 (r7笔记第58天)

今天早上开发的一个同事找到我说他早上做了一个统计查询,但是感觉速度很慢,已经过了一个小时了还没有反应。想让我看看是什么情况。 我通过v$session查到有一个...

3255
来自专栏沃趣科技

innodb存储引擎锁的实现

通常,我们在95%以上的MySQL使用场景中,从一定程度上来讲,就是在使用InnoDB存储引擎,很多时候我们选择使用InnoDB存储引擎的原因,就是因为它支持高...

965
来自专栏数据和云

MySQL - 8种常见的SQL错误用法

前言:MySQL在2016年仍然保持强劲的数据库流行度增长趋势。越来越多的客户将自己的应用建立在MySQL数据库之上,甚至是从Oracle迁移到MySQL上来。...

3264
来自专栏杨建荣的学习笔记

两个死锁的实例 (r5笔记第90天)

关于数据库中的死锁。如果在应用中碰到都会毫不犹豫转交给DBA,但是从目前我接到的deadlock的问题来看,和Oracle官方的描述基本都是一致的。 The f...

3006
来自专栏数据和云

【动手实践】Oracle 12.2 新特性:只读分区的使用和维护

在12.2的分区新特性中引入了只读分区的特性,可以帮助我们将某些分区的数据进行静态化保护。 这一特性通过将表或者分区设置为READ ONLY或者READ WRI...

2737
来自专栏数据库

采用Opserver来监控你的ASP.NET项目系列

前言 之前有过2篇关于如何监控ASP.NET core项目的文章,有兴趣的也可以看看. 今天我们主要来介绍一下,如何使用Opserver监控我们的SQL Ser...

1748
来自专栏散尽浮华

利用mk-table-checksum监测Mysql主从数据一致性操作记录

前面已经提到了mysql主从环境下数据一致性检查:mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理 今天这里再介...

2448
来自专栏乐沙弥的世界

Oracle 索引监控(monitor index)

      合理的为数据库表上创建战略性索引,可以极大程度的提高了查询性能。但事实上日常中我们所创建的索引并非战略性索引,恰恰是大量冗余或是根本没有用到的索引耗...

561

扫描关注云+社区