ORACLE怎样导出单张表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ORACLE怎样导出单张表相关的知识,希望对你有一定的参考价值。

导出的方法很多:
(1)数据量少的情况可以直接用pl/sql developer
(2)数据量大可以使用expdp命令(只能在服务端),exp(客户端服务端皆可)
(3)写一脚本,导出为xls文件
第一个脚本,main.sql
set linesize 200
set term off verify off feedback off pagesize 999
set markup html on entmap ON spool on preformat off
spool tables.xls
@get_tables.sql
spool off
exit
第二个脚本,get_tables.sql
里面是具体的查询sql
然后执行会得到一个table.xls的文件就是
参考技术A exp username/password tables=emp file=F:\exp_emp.dmp log=F:\exp_emp.log本回答被提问者采纳 参考技术B 1. 用pl/sql developer之类的工具导出
2. exp也可以导出单张表的。

oracle exp不能导出空表,怎样才能导出空表的结构呢?imp怎么导入空表结构?

--空表不能导出是因为11g中的不曾插入数据的空表是不分配存储单元的,当前用户下直接执行:select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0,得到的结果是“‘给当前用户下的空表分配空间’的语句”,导出或复制这些语句,直接执行这些语句,然后再次执行导出语句,就能导出所有表(包含空表),直接导入就好了,就会包含所有空表 参考技术A E:\Temp>exp -help

关键字 说明(默认) 关键字 说明(默认)
------------------------------------------------------------------------
USERID 用户名/口令 FULL 导出整个文件 (N)
BUFFER 数据缓冲区大小 OWNER 所有者用户名列表
FILE 输出文件 (EXPDAT.DMP) TABLES 表名称列表
COMPRESS 导入到一个区 (Y) RECORDLENGTH IO 记录的长度
GRANTS 导出权限 (Y) INCTYPE 增量导出类型
INDEXES 导出索引 (Y) RECORD 跟踪增量导出 (Y)
DIRECT 直接路径 (N) TRIGGERS 导出触发器 (Y)
LOG 屏幕输出的日志文件 STATISTICS 分析对象 (ESTIMATE)
ROWS 导出数据行 (Y)

你尝试 exp 的时候, 增加一个 ROWS=N 的参数看看?追问

可是我导入不了空表结构

参考技术B 在导出和导入的时候使用参数 ROWS=N就可以了。追问

导出时生成了dmp文件,但是显示这个表不存在
我再将这个dmp导入到另外一个数据库,也没有导入成功

追答

11g么?这个表没有数据吧?
11g有一个情况,有一个参数默认如果一张表没有数据,就不给它分配空间,那么导出的时候就不导出这张表。
复杂的处理办法是修改参数,然后重启数据库,然后重新建立这张表。
简单的办法就是往这个表里面插入一条数据,然后提交,再把这条数据删除了,在提交。
参数的名字是:deferred_segment_creation 可以查询一下。

追问

好像是的 我往表里插入一条数据就可以导入导出了 ,嘿嘿,谢谢你哈

本回答被提问者采纳
参考技术C 导出时加一个参数rows=n就导出表结构,不导数据 参考技术D 把所有的空表
alter table 表名 allocate extent;
改了后,再导出,用的是oracle 11g吧

以上是关于ORACLE怎样导出单张表的主要内容,如果未能解决你的问题,请参考以下文章

PLSQL怎样导出oracle表结构

PLSQL怎样导出oracle表结构

PLSQL怎样导出oracle表结构和数据

oracle中怎样把表、表空间导入或导出?

PLSQL怎样导出oracle表结构和数据

oracle exp不能导出空表,怎样才能导出空表的结构呢?imp怎么导入空表结构?