文档章节

轻松解决oracle11g 空表不能exp导出的问题。

陈爱茹cx1992
 陈爱茹cx1992
发布于 2016/07/26 17:36
字数 384
阅读 3
收藏 0

oracle11g的新特性,数据条数是0时不分配segment,所以就不能被导出。
 
解决方法:
 
1插入一条数据(或者再删除),浪费时间,有时几百张表会累死的。
2创建数据库之前
使用代码:

Sql代码 
alter system set  deferred_segment_creation=false; 
 
调整再建表
这两种方都不好
下面是终极方法:
 
先查询一下哪些表是空的:

Sql代码 
select table_name from user_tables where NUM_ROWS=0; 
 
 
下面我们通过select 来生成修改语句:
Sql代码 
select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 
 
然后就在结果窗口里面生成了下面那些东西:
 
Sql代码 
alter table E2USER_STATE allocate extent; 
alter table ENTERPRISE_E2USER allocate extent; 
alter table ENTERPRISE_INFO_TYPE allocate extent; 
alter table ENTERPRISE_MAPMARK allocate extent; 
alter table ENTERPRISE_NEEDTASK allocate extent; 
alter table ENTERPRISE_PICTURE allocate extent; 
alter table ENTERPRISE_REPORT allocate extent; 
alter table ENTERPRISE_REPORT_TYPE allocate extent; 
alter table ENTERPRISE_TEAM allocate extent; 
alter table FROMUSER_ADJUNCT_TARGET allocate extent; 
alter table FROMUSER_OFFER allocate extent; 
alter table NEEDTASK_TYPE allocate extent; 
alter table SYS_PRIVILEGE allocate extent; 
alter table SYS_RELEVANCE_RESOURCE allocate extent; 
alter table SYS_RELEVANCE_TARGET allocate extent; 
alter table SYS_RESOURCE_TYPE allocate extent; 
alter table TASK_FEEDBACK allocate extent; 
alter table TASK_MYTASKTYPE allocate extent; 
alter table TOUSER_MESSAGE allocate extent; 
alter table ABOUTUSER_POINT allocate extent; 
alter table ABOUTUSER_POINT_MARK allocate extent; 
alter table ABOUTUSER_QUERYKEY allocate extent; 
alter table ABOUTUSER_REPORT_HISTORY allocate extent; 
alter table DICT_COMMENT_TYPE allocate extent; 
alter table DICT_INDUSTRY_TYPE allocate extent; 
alter table DICT_POST allocate extent; 
alter table DICT_REGION allocate extent; 
alter table ENTERPRISE_COMMENT allocate extent; 
alter table ENTERPRISE_COMMENT_C allocate extent; 
alter table ENTERPRISE_INFO allocate extent; 
alter table ENTERPRISE_INFO_C allocate extent; 
alter table ENTERPRISE_INFO_STATE allocate extent; 
alter table CALENDAR_CREATETYPE allocate extent; 
alter table CALENDAR_MY allocate extent; 
alter table CALENDAR_TYPE allocate extent; 
 
 
 
ok 执行上面那些sql,之后再exp吧,那就是见证奇迹的深刻。

作者“那一夜未眠”


本文转载自:http://blog.csdn.net/ruru7989/article/details/25110453

共有 人打赏支持
陈爱茹cx1992
粉丝 0
博文 59
码字总数 0
作品 0
济南
程序员
私信 提问
oracle11g导出数据库空表

项目中使用oracle11g的情况越来越常见,也经常会基于oracle11g数据库的数据迁移。缘于oracle11g的一个特性,默认情况下,oracle不会给空表分配表空间,对于这些空表,使用exp命令做导出的时候...

彭苏云
2014/03/26
0
0
(转)oracle11g 不能导出空表解决办法

今天升级的时候实施跟我说 他加了一张表 但是用oracle 的exp的时候 显示该表不存在。排查了下 原来是那张表没有数据。 oracle11g 有显示 不允许导出空表。于是便有了下面的资料,谷歌别人也遇...

渔樵耕读
2014/03/28
0
0
解决oracle11g数据库中空表exp无法导出的问题

之前再做项目的时候下载了一个开源的程序,数据库在移植的时候通过exp/imp导入导出,结果程序在启动时报错,对比过后发现两个数据库表相差了十几个,再排查问题,发现少掉的十几个表全部是空...

一页之秋
2014/07/07
0
0
Oracle 11g 使用exp命令 导出空表

1、Oracle11g默认对空表不分配segment,故使用exp导出Oracle11g数据库时,空表不会导出。 2、设置deferredsegmentcreation 参数为FALSE后,无论是空表还是非空表,都分配segment。 在sqlplus...

IT_小翼
2013/11/13
0
0
Oracle数据库的备份与恢复

Oracle数据库有三种标准的备份方法,它们分别是导出/导入(EXP/IMP)、热备份和冷备份。导出备件是一种逻辑备份,冷备份和热备份是物理备份。 导出/导入(Export/Import)   利用Export可将数据...

libao2235
2018/06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Django进阶 1.1 ORM基础—ORM 1.2.1 增删改查之查询 1.2.2 删改增 (1) 1.2.3 删改增 (2)

ORM基础 ORM是Django操作数据库的API,Django的作者将sql语句封装在里面供我们使用。 我们前面还提到过Django提供一个模拟数据库的工具,sqlite,供我们学习测试使用。 如果我们想使用mysql...

隐匿的蚂蚁
今天
1
0
Windows 上安装 Scala

在安装 Scala 之前需要先安装 Java 环境,具体安装的详细方法就不在这里描述了。 您可以自行搜索我们网站中的内容获得其他网站的帮助来获得如何安装 Java 环境的方法。 接下来,我们可以从 ...

honeymose
今天
3
0
数据库篇多表操作

第1章 多表操作 实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表。且这些表的数据之间存在一定的关系...

stars永恒
今天
3
0
nginx日志自动切割

1.日志配置(Nginx 日志) access.log----记录哪些用户,哪些页面以及用户浏览器,IP等访问信息;error.log------记录服务器错误的日志 #配置日志存储路径:location / {      a...

em_aaron
昨天
5
0
java 反射

基本概念 RTTI,即Run-Time Type Identification,运行时类型识别。RTTI能在运行时就能够自动识别每个编译时已知的类型。   要想理解反射的原理,首先要了解什么是类型信息。Java让我们在运...

细节探索者
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部