物化视图是否可以exp导出_用EXP、IMP迁移包含物化视图日志的数据

在Oracle数据库中,物化视图日志在EXP/IMP数据迁移后可能会失效,尤其是当用户在不同库之间迁移时。文章通过实例详细介绍了三种不同情况下的物化视图日志行为:1) 导入到同一库的不同用户,导致物化视图日志失效;2) 导入到其他库的其他用户,物化视图日志无法成功创建;3) 导入到其他库的相同用户,物化视图日志可成功导入并正常工作。解决方案包括重建物化视图日志和触发器。
摘要由CSDN通过智能技术生成

2014-1-15日修改下面文章:物化视图日志的迁移由于不能更改创建物化日志的用户名,所以导致不是同名的用户入库会失效,这是oracle的bug,如果非要不同名用户下使用,可以使用以下语句建立新的内部触发器:

exec dbms_snapshot_utl.sync_up_log(‘ring’,’T_USERINFO’);

select * from dba_internal_triggers where table_name=’T_USERINFO’and  Owner_name=’RING’;

这个问题给我最大感触:迁移数据库的时候,要保持新库和老库都一样,包含全局名,sid,用户名等,这样就不会出现乱七八糟的问题,这也是比较傻瓜的迁移方式。

今天在测试环境中,原来正常快速刷新的物化视图不能同步数据了,最后发现是因为在同一个库做exp、imp操作后使得物化视图日志失效了,不记录基表的数据变化了。

在解决问题的过程中发现了其他一些问题,这里一并记录。

源库:a@TEST1> select * from v$version;

BANNER

----------------------------------------------------------------

Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production

PL/SQL Release 9.2.0.1.0 - Production

CORE 9.2.0.1.0 Production

TNS for 32-bit Windows: Version 9.2.0.1.0 - Production

NLSRTL Version 9.2.0.1.0 - Production

--在源库创建用户sys@TEST1> create user a identified by a default tablespace suk;

用户已创建。

sys@TEST1> create user b identified by b default tablespace suk;

用户已创建。

sys@TEST1> grant connect,resource,create materialized view to a;

授权成功。

sys@TEST1> grant connect,resource,create materialized view to b;

授权成功。

sys@TEST1> conna/a@suk

已连接。a@TEST1> create table t(a int primary key);

表已创建。

a@TEST1> create materialized view log on t;

实体化视图日志已创建。

a@TEST1> insert into t values(1);

已创建 1 行。

a@TEST1> commit;

提交完成。

a@TEST1> select * from mlog$_t;

A SNAPTIME$$ D O CHANGE_VE

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值