oracle学习7-导出导入数据库

简介: oracle学习7-导出导入数据库

oracle11g数据库导入导出:

①:传统方式——exp(导出)和(imp)导入:

②:数据泵方式——expdp导出和(impdp)导入;

③:第三方工具——PL/sql Develpoer;

一、什么是数据库导入导出?

oracle11g数据库的导入/导出,就是我们通常所说的oracle数据的还原/备份。

数据库导入:把.dmp 格式文件从本地导入到数据库服务器中(本地oracle测试数据库中);

数据库导出:把数据库服务器中的数据(本地oracle测试数据库中的数据),导出到本地生成.dmp格式文件。

.dmp 格式文件:就是oracle数据的文件格式(比如视频是.mp4 格式,音乐是.mp3 格式);

二、二者优缺点描述:

1.exp/imp:

优点:代码书写简单易懂,从本地即可直接导入,不用在服务器中操作,降低难度,减少服务器上的操作也就 保证了服务器上数据文件的安全性。

缺点:这种导入导出的速度相对较慢,合适数据库数据较少的时候。如果文件超过几个G,大众性能的电 脑,至少需要4~5个小时左右。

2.expdp/impdp:

优点:导入导出速度相对较快,几个G的数据文件一般在1~2小时左右。

缺点:代码相对不易理解,要想实现导入导出的操作,必须在服务器上创建逻辑目录(不是真正的目录)。我们 都知道数据库服务器的重要性,所以在上面的操作必须慎重。所以这种方式一般由专业的程序人员来完 成(不一定是DBA(数据库管理员)来干,中小公司可能没有DBA)。

3.PL/sql Develpoer:

优点:封装了导入导出命令,无需每次都手动输入命令。方便快捷,提高效率。

缺点:长时间应用会对其产生依赖,降低对代码执行原理的理解。

三、特别强调:

目标数据库:数据即将导入的数据库(一般是项目上正式数据库);

源数据库:数据导出的数据库(一般是项目上的测试数据库);

1.目标数据库要与源数据库有着名称相同的表空间。

2.目标数据在进行导入时,用户名尽量相同(这样保证用户的权限级别相同)。

3.目标数据库每次在进行数据导入前,应做好数据备份,以防数据丢失。

4.使用数据泵时,一定要现在服务器端建立可用的逻辑目录,并检查是否可用。

5.弄清是导入导出到相同版本还是不同版本(oracle10g版本与oracle11g版本)。

6.目标数据导入前,弄清楚是数据覆盖(替换),还是仅插入新数据或替换部分数据表。

7.确定目标数据库磁盘空间是否足够容纳新数据,是否需要扩充表空间。

8.导入导出时注意字符集是否相同,一般Oracle数据库的字符集只有一个,并且固定,一般不改变。

9.导出格式介绍:

Dmp格式:.dmp是二进制文件,可跨平台,还能包含权限,效率好;

Sql格式:.sql格式的文件,可用文本编辑器查看,通用性比较好,效率不如第一种,

适合小数据量导入导出。尤其注意的是表中不能有大字段 (blob,clob,long),如果有,会报错;

Pde格式:.pde格式的文件,.pde为PL/SQL Developer自有的文件格式,只能用PL/SQL Developer工具

导入导出,不能用文本编辑器查看;

10.确定操作者的账号权限。

四、二者的导入导出方法:

1、传统方法:

通用命令:exp(imp) username/password@SERVICENAME:1521 file=“e:\temp.dmp” full = y;

数据库导出举例:

exp xinxiaoyong/123456@127.0.0.1:1521 file=“e:\temp.dmp” full = y;

exp:导出命令,导出时必写。

imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。

username:导出数据的用户名,必写;

password:导出数据的密码,必写;

@:地址符号,必写;

SERVICENAME:Oracle的服务名,必写;

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

file=“e:\temp.dmp” : 文件存放路径地址,必写;

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

方法细分:

1.完全导入导出:

exp(imp) username/password@SERVICENAME:1521 file=“e:\temp.dmp” full = y;

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

exp(imp) username/password@SERVICENAME:1521 file=“e:\temp.dmp” tabels= (table1,table2,table3,…);

3.表空间tablespaces导入导出:

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

exp(imp) username/password@SERVICENAME:1521 file=“e:\temp.dmp” tablespaces= (tablespace1,tablespace2,tablespace3,…);

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

exp(imp) username/password@SERVICENAME:1521 file=“e:\temp.dmp” owner(username1,username2,username3);

2、数据泵方法:

创建directory:

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

数据库导出举例:

expdp xinxiaoyong/123456@127.0.0.1:1521 schemas=xinxiaoyong dumpfile=test.dmp

logfile=test.log directory=testdata1;

exp:导出命令,导出时必写。

imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。

username:导出数据的用户名,必写;

password:导出数据的密码,必写;

@:地址符号,必写;

SERVICENAME:Oracle的服务名,必写;

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

schemas:导出操作的用户名;

dumpfile:导出的文件;

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

directory:创建的文件夹名称;

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

1.查看表空间:

select * form dba_tablespaces;

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

select * form dba_directories;

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

create directory testdata1 as ‘d:\test\dump’;

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

//xinxiaoyong 是用户名(123456是用户密码)

grant read,write on directory testdata1 to xinxiaoyong;

5.导出数据

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

2)并行进程parallel expdp xinxiaoyong/123456@orcl directory=testdata1 dumpfile=xinxiaoyong3.dmp parallel=40 job_name=xinxiaoyong3

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

4)按查询条件导 expdp xinxiaoyong/123456@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 xinxiaoyong/123456 directory=testdata1 dumpfile=expdp.dmp schemas=xinxiaoyong;

2)改变表的owner impdp system/manager directory=testdata1 dumpfile=expdp.dmp tables=xinxiaoyong.dept remap_schema =xinxiaoyong: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;

3、PLSQL方法:

登录plsql工具,所使用用户为源数据库有导出权限(exp_full_database,dba等)的用户。

1.导出建表语句(包括存储结构)

导出步骤tools ->export user object,选择要导出的对象,导出.sql格式文件并等待导出完成,如 下图:

image.png

导出数据文件 ;

  2.导出步骤tools ->export tables,选择要导出的表及导出的格式进行导出。

导出为dmp格式,如下图:

image.png

导出为sql格式,如下图:

image.png

导出为pde格式,如下图:

image.png

提示说明:采用第三方工具导出导入整个数据库的话,耗时较长,一定要有足够

                   的时间来操作(数据量大的话需要好几个小时)。

3.导入建表语句

导入步骤tools->import tables->SQL Inserts 导入.sql文件

4.导入数据;

tools->import talbes,然后再根据导出的数据格式选择导入dmp文件,或者sql文件,

或者pde文件。

提示说明:导入之前最好把以前的表删除,当然导入另外数据库除外。

另外导入时当发现进度条一直卡在一个点,而且导出的文件不再增大时,甚至是提示程序

未响应,千万不要以为程序卡死了,这个导入导出就是比较缓慢,只要没有提示报错,

或者导入完成就不要停止程序。

CREATE OR REPLACE DIRECTORY mydir AS ‘D:\mydir’;–创建逻辑目录mydir

–在windows的同一位置建立一个文件,也就是d盘下面,把dmp文件放在下面

Impdp wiicare/123456@wiicare directory=mydir dumpfile=WIICARE.DMP

按照账号密码 导入指定的数据文件

remap_tablespace将一个表空间映射到另一个表空间

=TSP_WIICARE:wiicare remap_schema将一个方案中的对象放到另一个方案中

=wiicarebase:wiicare

image.png

导出exp

exp wlj/wlj@orcl file=d:exportoracle.dmp full=y 账号密码。导出库到d盘下名字叫做exportoracle.dmp

导出数据泵

image.png

相关文章
|
18天前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
6天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—异常断电导致Oracle数据库数据丢失的数据恢复案例
Oracle数据库故障: 机房异常断电后,Oracle数据库启库报错:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。数据库没有备份,归档日志不连续。用户方提供了Oracle数据库的在线文件,需要恢复zxfg用户的数据。 Oracle数据库恢复方案: 检测数据库故障;尝试挂起并修复数据库;解析数据文件。
|
6天前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
17 2
|
25天前
|
Oracle 安全 关系型数据库
Oracle数据恢复—Oracle数据库误删除的数据恢复方法探讨
删除Oracle数据库数据一般有以下2种方式:delete、drop或truncate。下面针对这2种删除oracle数据库数据的方式探讨一下oracle数据库数据恢复方法(不考虑全库备份和利用归档日志)。
|
9天前
|
SQL Oracle 关系型数据库
Oracle数据库管理:从入门到精通
表(Table):表是Oracle数据库中存储数据的基本结构单元,由行(Row)和列(Column)组成。每行代表一个记录,每列代表一个字段。 SQL(Structured Query Language):SQL是Oracle数据库的核心语言,用于与数据库交互,执行查询、插入、更新和删除等操作。 数据库实例与数据库:在Oracle中,数据库实例是一组后台进程和内存结构,用于管理数据库并提供服务。而数据库则是数据的物理存储,包括数据文件、控制文件、联机日志和参数文件等。
31 0
|
Oracle 关系型数据库 数据库
Oracle创建库
oracle创建表空间 SYS用户在CMD下以DBA身份登陆: 在CMD中打sqlplus /nolog 然后再 conn / as sysdba --如果路径不存在则要创建路径 --创建临时表空间 create temporary tablespace txwh...
753 0
|
2月前
|
存储 自然语言处理 Oracle
Oracle数据库字符集概述及修改方式
【8月更文挑战第15天】Oracle 数据库字符集定义了数据的编码方案,决定可存储的字符类型及其表示方式。主要作用包括数据存储、检索及跨系统传输时的正确表示。常见字符集如 AL32UTF8 支持多语言,而 WE8MSWIN1252 主用于西欧语言。修改字符集风险高,可能导致数据问题,需事先备份并评估兼容性。可通过 ALTER DATABASE 语句直接修改或采用导出-导入数据的方式进行。完成后应验证数据完整性。此操作复杂,须谨慎处理。
|
2月前
|
数据采集 Oracle 关系型数据库
实时计算 Flink版产品使用问题之怎么实现从Oracle数据库读取多个表并将数据写入到Iceberg表
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
1月前
|
存储 Oracle 关系型数据库
Oracle同一台服务器创建多个数据库
【8月更文挑战第30天】在 Oracle 中,可在同一服务器上创建多个数据库。首先确保已安装 Oracle 软件并具有足够资源,然后使用 DBCA 工具按步骤创建,包括选择模板、配置存储及字符集等。重复此过程可创建多个数据库,需确保名称、SID 和存储位置唯一。创建后,可通过 Oracle Enterprise Manager 进行管理,注意服务器资源分配与规划。
38 10
|
2月前
|
存储 Oracle 关系型数据库
分享几个Oracle数据库日常维护中常见的问题
分享几个Oracle数据库日常维护中常见的问题
84 1

热门文章

最新文章

推荐镜像

更多
下一篇
无影云桌面