oracle数据库导出导入

一.前言:

数据库CLOB类型的字段不能通过sqldeveloper工具导出sql文件。而且需要导出大批量数据的时候,最好通过exp/imp 命令实现数据库复制。部分内容转载

二.windows中使用

1. exp命令有三种导出方式(数据库、用户、表)

(1)完全导出:

exp hdfs/123456@orcl file=d:\database.dmp log=d:\database.log full=y

(2)导出用户:

exp hdfs/123456@orcl file=d:\database.dmp log=d:\database.log owner=hdfs

exp中full=y和owner=XX是不能同时使用的。

(3)导出表:

exp hdfs/123456@orcl file=d:\database.dmp log=d:\database.log tables=(b_role,b_users)

2. imp命令有三种导入方式(数据库、用户、表)

(1)完全导入:(一般不使用该方式)

imp hdfs/123456@orcl file=d:\database.dmp log=d:\database.log

(2)导入用户:(常用)

imp hdfs/123456@orcl file=d:\database.dmp log=d:\database.log fromuser=hdfs_old touser=hdfs

(3)导入表:(了解)

imp hdfs/123456@orcl file=d:\database.dmp log=d:\database.log tables=(b_role,b_users)

二.Linux中使用

创建逻辑目录:
Mkdir /home/ord

sqlplus连接

sqlplus /nolog
conn / as sysdba


一、创建逻辑目录,该命令不会在操作系统创建真正的目录(请先创建真正的目录),最好以system等管理员创建逻辑目录。

SQL>create directory ord as '/home/ord';

二、查看管理员目录(同时查看操作系统是否存在,因为oracle并不关心该目录是否存在,假如不存在,则出错)
SQL>select * from dba_directories;

三、用expdp导出数据,退出sqlplus,在控制台里运行

5)  导出整个数据库(包换各用户 比如sunams sunflow等)
expdp \'/ as sysdba\' directory=bak dumpfile=full.dmp full=y;

4)导入数据库
impdb  \'/ as sysdba\' directory=ord  dumpfile=full.dmp full=y;

导出用户sunams:
exp sunams/sunams file=/home/oracle/bak/bak.dump owner=sunams
导出指定的表ams_notice:
Linux导出到本地windows数据库
exp sunams/sunams file=/home/oracle/bak/bak.dmp log=/home/oracle/bak/database.log tables=(ams_notice)
imp sunams/sunams@orcl file=C:\Users\Administrator\Desktop\bak.dmp log=d:\database.log tables=(ams_notice)

对于导入导出表空间名不一致的问题,我们可通过修改用户下的表空间名来解决。

alter tablespace users rename to usersts;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值