在给客户培训的过程中,发现客户数据库服务器存在一个奇怪的现象。客户数据库服务器环境为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
分享到:
相关推荐
执行EXP导出时,部分表提示 EXP-00011:表不存在错误,但是查询user_all_tables视图,此表确实是存在的,并且执行select语句也能成功,不过表为空表,查看权限等也没有问题。后来通过查询资料,发现问题是由Deferred ...
Oracle 11g R2 中 exp 无法导出空表的解决方法 Oracle 11g R2 中新增的特性,使得 exp 无法导出空表,这是因为 11g R2 中有一个新特性,即当表无数据时,不分配 segment,以节省空间。这种情况下,使用 exp 命令...
Oracle Linux 11gR2 x86-64 Instant Client是Oracle公司为Linux平台提供的一款轻量级数据库连接工具,专为那些不需要完整数据库服务器安装但需要与Oracle数据库进行交互的应用程序设计。这个版本特别适用于开发人员...
2. **Oracle 11gR2中无法使用EXP导出空表的问题**: - 在Oracle 11gR2中,如果尝试使用传统的EXP工具导出包含空表的数据库,空表可能不会被包含在导出文件中。这是由于EXP工具的设计限制,它主要关注于用户数据的...
在Oracle 11g R2中,exp已经更新为expdp(Data Pump Export),它提供了更快的导出速度和更高级的选项,例如并行导出、表空间过滤以及导出元数据等。 2. **imp工具**:Import工具则用于将exp创建的转储文件中的数据...
在Oracle 11gR2版本中,Oracle数据库引入了一个新的特性——延迟段创建(Deferred Segment Creation)。这个特性主要是为了优化空间管理,特别是在处理大量空表时,可以有效地避免不必要的磁盘空间占用。延迟段创建...
Oracle 11gR2是Oracle数据库的一个重要版本,它在11g的基础上进行了许多功能增强和性能优化,尤其在数据管理和恢复方面有着显著的进步。本资料主要关注11gR2的数据备份与恢复机制,这包括了Oracle的EXP(Export)和...
oracle11gR2版本之后,新建表默认是不初始化空间的,exp导出的时候,这些空表是不导出的
Oracle 11gr2 是 Oracle 11g 第二版的简称,它提供了许多增强功能和改进,特别是在性能和可用性方面。以下是安装 Oracle 11gr2 的主要步骤: 1. **用户与权限设置**: - 创建新的 Oracle 用户和组。 - 配置正确的...
这里,我们使用 exp 命令将 Windows 服务器下的 Oracle 数据库导出到本地 D:\backup 目录中。exp 命令可以根据需要导出特定的用户数据和权限。 五、数据库导入 数据库导入是指将数据从一个数据库导入到另一个...
这个脚本使用了Oracle的`exp`命令来导出数据库,并使用`zip`命令进行压缩。`-m`参数表示原地压缩,即删除原始的`.dmp`文件。 3. **设置定时执行** 为了自动化这个过程,你可以使用`cron`服务来定时执行这个shell...