关于oracle11g空表无法导出的问题

会飞的鱼1993 2018-10-31 11:39:30
1.为什么会出现该问题 racle 11g中有个新特性,当表无数据时,不分配segment,以节省空间,当我们用exp导出空表时,无法导出。解决方法是两个方面,一是处理现有的空表,让其能导出;二是设置参数,让后续的新的空表也可以导出。 2.解决方法 1.)在建用户时处理该问题! 设置系统参数,让后续新表自动分配segment,查询系统参数,该参数值默认是TRUE,当改为FALSE时,无论是空表还是非空表,都分配segment. 查询语句:show parameter deferred_segment_creation; 将这个参数修改为FALSE,修改语句为: alter system set deferred_segment_creation=false; 再次查询确认参数是否修改成功: show parameter deferred_segment_creation; 再执行导出问题已解决! 2.之前未修改空表参数,后续使用中发现个别空表无法导出。 登录当前需导出的用户,执行以下语句 alter table 空表表明 allocate  extend; 再导出改表即可!
...全文
161 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhx0114 2018-11-10
  • 打赏
  • 举报
回复
执行一下这个SQL:
Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 or num_rows is null;
把查询出来的结果贴出来执行一下就可以了
minsic78 2018-11-03
  • 打赏
  • 举报
回复
这个怎么能说是BUG…… oracle明确这个特性带来的影响,并给出了解决方法,而且10g以后oracle就推荐用数据泵了,当然非要说BUG也行,但在这个时代,Oracle有时间去修改这种代码,还不如多多解决rman备份时候的BUG,毕竟这个才算是真正的备份,逻辑备份工具只是辅助而已。
ckc 2018-11-03
  • 打赏
  • 举报
回复
当然是bug。我并不是说这个新特性有问题,为了更快影响create table在建表时不分配空间是合理的,不过这个新特性需要考虑对其它功能的影响,现在它影响到了备份,这其实是个很严重的bug。莫非oracle特意让备份出问题?
chuwaqin 2018-11-03
  • 打赏
  • 举报
回复
引用 7 楼 minsic78 的回复:
这个怎么能说是BUG…… oracle明确这个特性带来的影响,并给出了解决方法,而且10g以后oracle就推荐用数据泵了,当然非要说BUG也行,但在这个时代,Oracle有时间去修改这种代码,还不如多多解决rman备份时候的BUG,毕竟这个才算是真正的备份,逻辑备份工具只是辅助而已。
完全正确 应该使用 expdp
卖水果的net 2018-11-02
  • 打赏
  • 举报
回复
引用 3 楼 ckc 的回复:
这个要算是oracle的bug吧
引用 4 楼 u014525726 的回复:
算是了吧,建库时候设置一下也无所谓了
这个不是 bug ,是一个新特性。 也就是说特意做成这样了。 目的是为了更快的响应 create table 命令。
会飞的鱼1993 2018-11-02
  • 打赏
  • 举报
回复
算是了吧,建库时候设置一下也无所谓了
ckc 2018-11-01
  • 打赏
  • 举报
回复
这个要算是oracle的bug吧
卖水果的net 2018-10-31
  • 打赏
  • 举报
回复
2.解决方法 1.)在建用户时处理该问题! 不是建用户时处理, 其他的不错,建议记录在博客中。
会飞的鱼1993 2018-10-31
  • 打赏
  • 举报
回复
谢谢帮忙纠正,新手请多多关注

17,086

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧