Oracle 11g exp导出 deferred_segment_creation参数配置

Oracle11g一个新特性:新增了一个参数“deferred_segment_creation”含义是段延迟创建,默认是true。

如果这个参数设置为true,你新建了一个表Table1,并且没有向其中插入数据,那么这个表不会立即分配extent,也就是不占数据空间,即表也不分配segment以节省空间,所以这些表也没能导出来。在系统表user_tables中也可以看到segment_treated的字段里是“NO”或者“YES”说明了某张表是否分配了segment。目的是是为了可以节省少量的空间。


在10g客户端导11g数据库时若存在这样的空表,导出会失败 报错

EXP-00008: 遇到 ORACLE 错误 1455
ORA-01455: 转换列溢出整数数据类型
EXP-00000: 导出终止失败

使用11g客户端导出备份是可以正常执行,但数据库中空表是无法导出备份表结构的


解决方法:

步骤一 :

  设置deferred_segment_creation 参数:

  设置deferred_segment_creation参数为FALSE来禁用"段推迟创建"(也就是直接创建segment),无论是空表还是非空表,都分配segment。

  在sqlplus中,执行如下命令:

  SQL>alter system setdeferred_segment_creation=false;

  查看:

  SQL>show parameterdeferred_segment_creation;

   注意:该值设置后只对后面新增的表产生作用,对之前建立的空表(已经存在的)不起作用,仍不能导出。

  并且要重新启动数据库,让参数生效。


步骤二:

对已构建的空表分配空间

{

select table_name from user_tables whereNUM_ROWS=0;

alter table TableName allocate extent

单个操作太麻烦

}


SQL>Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 or num_rows is null


SQL>批量执行产生的 sql语句



至此,大功告成。










  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值