龙空技术网

oracle数据库中两种命令方式的数据导出和导入方法详解

小芒果爱发呆 672

前言:

而今我们对“oracle大量数据导入”可能比较关注,看官们都想要学习一些“oracle大量数据导入”的相关资讯。那么小编同时在网上收集了一些对于“oracle大量数据导入””的相关内容,希望看官们能喜欢,看官们快快来学习一下吧!

在对Oracle的数据操作过程中,常用到的就是在PLSQL端进行的操作,那么除了窗口操作之外,还有两种命令行方式的导出和导入方法,在这里对这两种方法进行详细介绍

一、普通方式——exp(导出)和(imp)导入:速度相对慢,可以传本地数据,安全性好

二、数据泵——expdp导出和(impdp)导入:需要在服务器创建逻辑目录,速度快,较复杂。

1、普通方式:

通用命令:exp(imp) username/password@服务名:1521 file="d:\temp.dmp" full = y;

数据库导出举例:

exp username/password@127.0.0.1:1521 file="d:\temp.dmp" full = y;

exp:导出命令

imp:导入命令

usernamd:导出数据的用户名

password:导出数据的密码

@:地址符号

服务名:Oracle的服务名;

1521:端口号,1521是默认的可以不写,非默认要写;

file="d:\temp.dmp" : 文件存放路径地址

full=y :表示全库导出。可以不写,则默认为no,则只导出用户下的对象;

方法细分:

1.完全导入导出:

exp(imp) username/password@SERVICENAMd:1521 file="d:\temp.dmp" full = y;

2.部分用户表table导入导出:

exp(imp) username/password@SERVICENAMd:1521 file="d:\temp.dmp" tabels= (table1,table2,table3,...);

3.表空间tablespaces导入导出:

//一个数据库实例可以有N个表空间(tablespace),一个表空间下可以有N张表(table)。

exp(imp) username/password@SERVICENAMd:1521 file="d:\temp.dmp" tablespaces= (tablespace1,tablespace2,tablespace3,...);

4.用户名username对象导入导出:

exp(imp) username/password@SERVICENAMd:1521 file="d:\temp.dmp" owner(username1,username2,username3);

2、数据泵:

创建directory:

expdp(impdp) username/password@SERVICENAMd:1521 schemas=username dumpfile=file1.dmp logfile=file1.log directory=testdata1 remap_schema=test:test;

数据库导出举例:

expdp username/password@127.0.0.1:1521 schemas=username dumpfile=test.dmp

logfile=test.log directory=testdata1;

exp:导出命令

imp:导入命令

usernamd:导出数据的用户名

password:导出数据的密码

@:地址符号

SERVICENAMd:Oracle的服务名

1521:端口号,1521是默认的可以不写,非默认要写;

schemas:导出操作的用户名;

dumpfile:导出的文件;

logfild:导出的日志文件,可以不写;

directory:创建的文件夹名称;

remap_schema=源数据库用户名:目标数据库用户名,二者不同时必写,相同可以省略;

1.查看表空间:

select * form dba_tablespaces;

2.查看管理理员目录(同时查看操作系统是否存在,因为Oracle并不关心该目录是否存在,如果不存 在,则出错)。

select * form dba_directories;

3.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建。

create directory testdata1 as 'd:\test\dump';

4.给username用户赋予在指定目录的操作权限,最好以system等管理员赋予。

//username 是用户名(password是用户密码)

grant read,write on directory testdata1 to username;

5.导出数据

1)按用户导 expdp username/password@orcl schemas=username dumpfile=expdp.dmp directory=testdata1;

2)并行进程parallel expdp username/password@orcl directory=testdata1 dumpfile=username3.dmp parallel=40 job_name=username3

3)按表名导 expdp username/password@orcl tables=emp,dept dumpfile=expdp.dmp directory=testdata1;

4)按查询条件导 expdp username/password@orcl directory=testdata1 dumpfile=expdp.dmp tables=emp query='WHERE deptno=20';

5)按表空间导 expdp system/manager directory=testdata1 dumpfile=tablespace.dmp tablespaces=temp,example;

6)导整个数据库 expdp system/manager directory=testdata1 dumpfile=full.dmp FULL=y;

6.还原数据

1)导到指定用户下 impdp username/password directory=testdata1 dumpfile=expdp.dmp schemas=username;

2)改变表的owner impdp system/manager directory=testdata1 dumpfile=expdp.dmp tables=username.dept remap_schema =usernamd:system;

3)导入表空间 impdp system/manager directory=testdata1 dumpfile=tablespace.dmp tablespaces=example;

4)导入数据库 impdb system/manager directory=dump_dir dumpfile=full.dmp FULL=y;

5)追加数据 impdp system/manager directory=testdata1 dumpfile=expdp.dmp schemas=system table_exists_action;

标签: #oracle大量数据导入 #导入oracle文件 #oracle重复数据不导入 #oracle的命令窗口在哪里 #oracle取符号函数