今天在做迁移数据库,从11.2.0.1迁移到11.2.0.4,用exp导出一个用户下所有的对象,在做imp导入的时候发现表少了很多,看日志后分析是部分空表没有导出。在网上查了一下,发现是11G中新特性,当表无数据时,不分配segment,以节省空间。而使用exp命令时,无Segment的表不会被导出。
解决方案的文章:
http://wenku.baidu.com/view/7beb56f57c1cfad6195fa702.html
最后我们采取了第三种:
用SQL拼接一个语句: select ‘alter table ‘||table_name||‘ allocate extent;’ from user_tables where num_rows=0;
:
alter table BUSEXTINFO allocate extent;
alter table BUSCHECKINFO allocate extent;
alter table HOMEMEMBER allocate extent;
alter table BUSASSEMBLYINFO allocate extent;
alter table BUSASSEMBLYHISTORY allocate extent;
alter table ASGNEMPDUTYPLUS allocate extent;
alter table JX_MAINTAINPEOPLELD allocate extent;
alter table MCBUSOILSTANDARDGS allocate extent;
alter table MCBUSOILSTDDETAILDGS allocate extent;
alter table FDISARRSEQUENCETIMELD allocate extent;
alter table FDISARRSEQUENCETMPLD allocate extent;
…….
最后执把这些语句执行一遍就OK了!
Oracle 11g 使用exp命令导出表不全的解决方案
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。