Oracle使用expdp/impdp导出导入数据
这里假设已存在数据库用户,并是计划通过该用户导入导出该用户表空间上的数据。(我们这里假定用户名称为ls)
1.创建逻辑目录(数据库命令,sqlplus中执行)
Oracle不能直接指定系统目录让他去读写文件,只能先将系统目录映射成Oracle中的逻辑目录其才能读写。
先以sysdb登录,将系统/oracle/dump目录映射成Oracle的逻辑目录impexp;然后赋给导入导出用户在该目录的读写权限
create directory impexp as '/oracle/dump';
grant read,write on directory impexp to ls;
另外后边的参logfile是用于记录导入导出的日志文件,文件名随意;schemas应该是导出的用户名。
2.expdp导出数据(非数据库命令,在主机命令行而非sqlplus中执行)
expdp ls/lsdb123#@lsdb directory=impexp dumpfile= lsdb.dmp logfile=lsdb.log schemas= ls
3.impdp导入数据(非数据库命令,在主机命令行而非sqlplus中执行)
impdp ls/lsdb123# directory=impexp dumpfile= lsdb.dmp logfile= lsdb.log schemas= ls
如果要导到的用户与导出dumpfile的用户名不一样则要使用remap_schema代替schemas,将旧用户名指向新用户名:
impdp user_new/pass_new directory=impexp dumpfile=lsdb.dmp loggfile=lsdb.log remap_schema=user_old:user_new
如果要导到的表空间名称不一样,则要使用remap_tablespace将旧表空间名指向新表空间名:
impdp ls/lsdb123# directory=impexp dumpfile=lsdb.dmp loggfile=lsdb.log schemas=ls remap_tablespace=tablespace_old:tablespace_new
如果要导到的用户名和表空间名与原来导出时的都不一样,那么要同时使用remap_schema和remap_tablespace:
impdp user_new/pass_new directory=impexp dumpfile=lsdb.dmp logfile=lsdb.log remap_schema=user_old:user_new remap_tablespace=tablespace_old:tablespace_new
如果导出的dmp文件中有多个表空间,那么remap_tablespace写多个:
impdp ls/lsdb123# directory=impexp dumpfile=lsdb.dmp loggfile=lsdb.log schemas=ls remap_tablespace='(tablespace_old1:tablespace_new1,tablespace_old2:tablespace_new2)'
如果原先已有数据,想使用覆盖导入使用table_exists_action=replace:
impdp ls/lsdb123# directory=impexp dumpfile= lsdb.dmp logfile= lsdb.log schemas= ls table_exists_action=replace
如果expdp限制了单个文件大小使用%U导出多个文件(比如6个),则导入:
impdp lsdb/lsdb123# directory=impexp dumpfile=lsdb_%U.dmp logfile= lsdb.log schemas= lsdb parallel=
4.导错处理
导入报错后一般是删除用户及其所有对象然后重导
drop user lsdb cascade; --删除lsdb用户及其所有对象
select sid,serial# from v$session where username='lsdb'; --如果用户存在活动会话则drop会失败所以先查找到用户会话
alter system kill session'sid_num,serial#_num'; --杀除用户会话
imp导入:
imp lsdb/lsdb123#@lsdb fromuser=lsdb touser=lsdb file=/oracle/backup/lsdb.dmp log=/oracle/backup/lsdb.log
格式:imp 数据库用户/用户密码@数据库实例 fromuser=导出时的用户 touser=导入到的用户 file=导出的dmp文件当前所在目录 log=导入日志文件要存放的位置
报错:IMP-00013: only a DBA can Import a file Exported by another DBA
原因:用于导入数据的lsdb用户没有dba权限
处理:使用sys等dba用户导入或赋权:grant imp_full_database to lsdb
执行脚本文件(类似mysql的source)
sqlplus user/pass@servicename</path/to/sql_script.sql
SQL>start /path/to/sql_script.sql
SQL>@ /path/to/sql_script.sql
参考:
http://blog.csdn.net/haitaofeiyang/article/details/72026962
http://blog.csdn.net/by84788186/article/details/8958332
http://www.jb51.net/article/76786.htm
Oracle使用expdp/impdp导出导入数据的更多相关文章
- linux 下使用exp/imp 或者expdp/impdp导出导入oracle数据表数据
一.环境配置 1.执行环境: exp/imp可以在客户端执行也可以在服务器端执行,在客户端执行需要先安装有oracle的客户端,如果是linux系统,就是以oracle用户登录,在控制台下执行.建议在 ...
- Oracle expdp/impdp导出导入命令及数据库备份
使用EXPDP和IMPDP时应该注意的事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用, ...
- Oracle expdp/impdp导出导入命令及数据库备份(转)
使用EXPDP和IMPDP时应该注意的事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用, ...
- Oracle数据库备份 expdp/impdp导出导入命令
使用EXPDP和IMPDP时应该注意的事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用, ...
- Oracle使用expdp/impdp迁移数据
Oracle使用expdp/impdp迁移数据 1.#以下步骤在开发库执行(expdp导出) 一.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建. sqlplus / ...
- GreenPlum/postgres copy命令导出/导入数据
一.COPY命令简单实用 1.copy在postgres与GreenPlum介绍 1.1 postgrespostgres的COPY命令可以快速的导出/导入数据到postgresql数据库中,支持常用 ...
- Linux服务器下对Oracle数据库expdp(导出)和impdp(导入)
紧接上篇文章,Oracle数据库架构已经创建完成,我的需求是:将老服务器上的数据库迁移到新的数据库上. 这就用到impdp(导入)操作. 要想实现对新数据库的impdp(导入)工作, 首先需要从老的数 ...
- ORACLE expdp/impdp导出实例
服务器上以sys或system超级管理员登录. SQL>create directory expdp_dir as '/home/oracle/dmpdata';(dmpdata 需要建立.赋予 ...
- expdp impdp 数据库导入导出命令详解
一.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建.create directory dpdata1 as 'd:\test\dump'; 二.查看管理理员目录(同时 ...
随机推荐
- ppython的移位操作
因为要将js的一个签名算法移植到python上,遇到一些麻烦. int无限宽度,不会溢出 算法中需要用到了32位int的溢出来参与运算,但是python的int是不会溢出的,达到界限后会自己转为lon ...
- 串口.Qt532测试(异步)
环境:Win7x64.Qt5.3.2 MSVC OpenGL(x86).vs2010(x86) 项目所在位置:E:\Project_Qt532\SeriesPort_Qt532_Z ZC:这里 同步方 ...
- Qt532.【转】Qt创建鼠标右键菜单
ZC:可以通过 设置 (QWebView*)->setContextMenuPolicy(NoContextMenu); 来关闭 QWebView的默认右键菜单 Qt创建鼠标右键菜单_疯华正茂 ...
- MYSQL常用函数(聚合函数(常用于GROUP BY从句的SELECT查询中))
AVG(col)返回指定列的平均值 COUNT(col)返回指定列中非NULL值的个数 MIN(col)返回指定列的最小值 MAX(col)返回指定列的最大值 SUM(col)返回指定列的所有值之和 ...
- 浏览器缓存之Expires Etag Last-Modified max-age详解
前段时间去面试移动端的H5开发工程师,在最后面试的时候被问到了max-age Expires Etag有什么不同,在什么情况下应用,当时乱编了一通,自我感觉良好,结果…… 大家懂得,现在讲他们几个的区 ...
- css动效库animate.css和swiper.js
animate.css https://daneden.github.io/animate.css/ 学习的文档:http://www.jq22.com/jquery-info819 腾讯团队的JXa ...
- word2010怎么把白色方框变成黑色方框?
word2010怎么把白色方框变成黑色方框? 打开Word 2010文档,选中第四个白色方框. 切换到“插入”功能区,在符号选项组单击“符号”按钮,出来的窗口单击“其他符号”. 在“符号”选项卡单 ...
- python中socket模块详解
socket模块简介 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket.socket通常被叫做"套接字",用于描述IP地址和端口,是一个通信 ...
- android AIDL 语言用法
跨进程通信可以用AIDL语言 这里讲述下如何使用AIDL语言进行跨进程通信 文章参考 <设计模式>一书 demo结构参考 主要的文件类有:IBankAidl.aidl java文件:Aid ...
- fedora21 中lamp的搭建(测试没有问题)
LAMP Stands for Linux,Apache,MySQL and PHP. Most of the websites works with the above combination. T ...