(FAQ)oracle导出数据库
金蝶云社区-金蝶云社区
金蝶云社区
0人赞赏了该文章 1,010次浏览 未经作者许可,禁止转载编辑于2015年03月02日 00:00:00
【问题】: (FAQ)oracle导出数据库
版本: 6.0
模块: 系统部署
【答复】:
原因分析: 不经常恢复数据库,经验少原因。 解决方法: 将数据库内的各对象以二进制方式下载成dmp文件,方便数据迁移。进入dos命令窗口,输入:exp help=y ; 便会列出exp的帮助提示,下面介绍下常用的关键字: buffer:下载数据缓冲区,以字节为单位,缺省依赖操作系统 consistent:下载期间所涉及的数据保持read only,缺省为n direct:使用直通方式 ,缺省为n feeback:显示处理记录条数,缺省为0,即不显示 file:输出文件,缺省为expdat.dmp filesize:输出文件大小,缺省为操作系统最大值 indexes:是否下载索引,缺省为n,这是指索引的定义而非数据,exp不下载索引数据 log:log文件,缺省为无,在标准输出显示 owner:指明下载的用户名 query:选择记录的一个子集 rows:是否下载表记录 tables:输出的表名列表 导出整个实例: exp dbuser/oracle file=oradb.dmp log=oradb.log full=y consistent=y direct=y 注:user应具有dba权限 导出某个用户所有对象 : exp dbuser/oracle file=dbuser.dmp log=dbuser.log owner=dbuser buffer=4096000 feedback=10000 导出一张或几张表: exp dbuser/oracle file=dbuser.dmp log=dbuser.log tables=table1,table2 buffer=4096000 feedback=10000 导出某张表的部分数据: exp dbuser/oracle file=dbuser.dmp log=dbuser.log tables=table1 buffer=4096000 feedback=10000 query=”where col1=’…’ and col2 <…” 注:不可用于嵌套表 以多个固定大小文件方式导出某张表 : exp dbuser/oracle file=1.dmp,2.dmp,3.dmp,… filesize=1000m tables=emp buffer=4096000 feedback=10000 这种做法通常用在:表数据量较大,单个dump文件可能会超出文件系统的限制 直通路径方式 direct=y,取代buffer选项,query选项不可用 ,有利于提高下载速度 ,consistent选项 ,自export启动后, consistent=y冻结来自其它会话的对export操作的数据对象的更新,这样可以保证dump结果的一致性。 但这个过程不能太长,以免回滚段和联机日志消耗完 。 关键字 安装