关于Oracle11gR2用EXP导出时报EXP-00011错误的解决方法
来源:互联网 发布:java应用架构设计 pdf 编辑:程序博客网 时间:2024/05/21 06:23
在给客户培训的过程中,发现客户数据库服务器存在一个奇怪的现象。客户数据库服务器环境为AIX6+Oracle11gR2,具体现象如下:
执行EXP导出时,部分表提示 EXP-00011:表不存在错误,但是查询user_all_tables视图,此表确实是存在的,并且执行select语句也能成功,不过表为空表,查看权限等也没有问题。后来通过查询资料,发现问题是由Deferred Segment Creation参数引起的。
Deferred Segment Creation,延迟段创建,Oracle11gR2新增参数, 具体用处是当新创建一个可能会有Segment的对象时,如果这个对象中还没有任何记录需要消耗一个Extent,那么将不会在创建对象时自动创建Segment,这样做的好处是在创建对象时大大提高了速度。但是这么一来,因为对象没有Segment,执行EXP导出时,就会报EXP-00011错误。
以报错的表cf_template为例,执行以下查询:
SQL> show parameter DEFERRED_SEGMENT_CREATION
NAME TYPE VALUE
------------------------------------ -------------------- --------------------
deferred_segment_creation boolean TRUE
发现Deferred Segment Creation已经打开,再执行:
SQL> select segment_name from user_segments where segment_name='CF_TEMPLATE';
no rows selected
没有返回值,数据库确实没有给CF_TEMPLATE表创建Segment,这就验证了为什么报错的都是空表。
解决方法如下:
1. 设置deferred_segment_creation的值为false
此方法只对以后的表有效,之前的表没有Segment的还是没有。
2. 创建表的时候声明立即创建Segment
create table XXX (XXX XXX) SEGMENT CREATION IMMEDIATE;
3.对于已经创建但是还没有Segment的表来说,可以执行alter table XXX allocate extent来使其创建出 Segment,当然也可以插入一条数据,使其创建Segment
- 关于Oracle11gR2用EXP导出时报EXP-00011错误的解决方法
- 关于Oracle11gR2用EXP导出时报EXP-00011错误的解决方法
- 关于Oracle11gR2用EXP导出时报EXP-00011错误的解决方法
- 关于Oracle11gR2用EXP导出时报EXP-00011错误的解决方法
- Oracle11gR2用EXP导出时报EXP-00011错误的解决
- Oracle11gR2用EXP导出时报EXP-00011错误的解决
- oracle11gR2 导出表报EXP-00011:table不存在。
- exp 导出 00091错误解决方法
- oracle exp导出时报EXP 00091错
- EXP-00024错误的解决方法
- ORA-01187 EXP导出错误解决方法
- Oracle exp 导出数据错误解决方法
- exp导出错误
- Oracle11g用exp无法导出空表的解决方法
- Oracle,用exp命令导出数据库时出现 EXP-00091 错误的解决办法
- EXP-00056错误解决方法
- EXP-00002错误解决方法
- Oracle 导出错误 EXP-00000~EXP-00107
- linux服务器指标命令 之 top
- UML用例图总结
- Android修炼之道—vine底层的尝试
- 做新郎也不容易啊
- 跳台阶
- 关于Oracle11gR2用EXP导出时报EXP-00011错误的解决方法
- 我是如何在GitHub上开源一个项目的(截图说明)
- 匹配html中的A标签
- 数组的定义
- 黑马程序员-多态
- C语言发送电子邮件
- POJ 3522 Slim Span 求一棵生成树,让最大边和最小边只差最小
- 一个是1970年11月11日出生, 一个是1984年7月7日出生,请问两人相差几年?几个月?几日?
- A:大小写