oracle11g数据库导入导出

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格式文件并等待导出完成,如       下图:

 

                                            

 

导出数据文件 ;

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

         导出为dmp格式,如下图:

 

 

 

导出为sql格式,如下图: 

 

 

 

导出为pde格式,如下图: 

 

 

 

 

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

 

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

 

3.导入建表语句 

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

4.导入数据; 

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

或者pde文件。 

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

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

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

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

 

提示:创建数据库,表空间这里略过,本文主要讨论数据的导入导出,如果对此感觉稍有遗漏,尽请见谅。由于水平有限,本文档仅提供参考。如代码有错误之处,请见谅。如果有更好的开发经验,感谢回复。谢谢观看!!!;

---------------------

作者:xinxiaoyong

来源:CSDN

原文:https://blog.csdn.net/xinxiaoyonng/article/details/79436673

版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值