>데이터 베이스 >MySQL 튜토리얼 >Oracle 11g的exp不能导出空表

Oracle 11g的exp不能导出空表

WBOY
WBOY원래의
2016-06-07 17:16:431287검색

由于公司内部没有Oracle 11g,以前也没怎么使用过该版本,所以一些新特性还不是很了解。这次导出11g的数据库,就遇到了exp不能导

由于公司内部没有Oracle 11g,以前也没怎么使用过该版本,所以一些新特性还不是很了解。这次导出11g的数据库,就遇到了exp不能导出空表的问题,折腾了好久也没搞明白,后来切换到expdp的数据泵方式,增加version参数,方便导入到10g数据库,终于完整的把数据库给导出了,包括100个多空表。
 
今天上网才了解到,原来这个exp不导出空表,是11g的新特性,,当表无数据时,不分配segment,以节省空间,所以exp导出的时候,不导出这些表。
 
针对这个问题,网上有个方便的解决方案。
 
用以下这句查找空表并生成执行命令
select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0;
 
把查询结果导出,执行导出的语句。
类似 alter table T_TAB allocate extent;
 
然后再用exp的方式去导出数据库,终于可以完整的导出包括空表的数据库。

linux

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.