正如标题一样,本文内容主要介绍了浅谈入门级oracle数据库数据导入导出步骤,文章通过步骤解析介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧!!!

oracle数据库数据导入导出步骤(入门)

说明:

1.数据库数据导入导出方法有多种,可以通过exp/imp命令导入导出,也可以用第三方工具导出,如:PLSQL

2.如果熟悉命令,建议用exp/imp命令导入导出,避免第三方工具版本差异引起的问题,同时效率更高,但特别注意:采用命令时要注意所使用的用户及其权限等细节。

3.在目标数据库导入时需要创建与导出时相同的用户名(尽量一致),并赋予不低于导出时用户的权限;同时还需创建与原数据库相同的表空间名,若本地数据库已存在相同的表空间,则只能进行表空间扩充。

一、导入前准备工作(在目标数据库操作)

知识补充: 表空间 Oracle数据库是通过表空间来存储物理表的,一个数据库实例可以有N个表空间,一个表空间下可以有N张表。  表空间(tablespace)是数据库的逻辑划分,每个数据库至少有一个表空间(称作SYSTEM表空间)。为了便于管理和提高运行效率,可以使用一些附加表空间来划分用户和应用程序。例如:USER表空间供一般用户使用,RBS表空间供回滚端使用。一个表空间只能属于一个数据库。

1. 登录服务器

 用Xshell或者secureCRT工具都可

2. 查询磁盘空间是否足够大

 执行df -h或者df -H命令进行查询,若可用空间不足则更换新的目标环境再继续其他操作。

[oracle@orac ~]$ df -h

3. 查询表空间详情

 ①使用终端登录,依次执行命令:

 在/home/oracle/app/oradata 目录下新建一个文件夹,后面创建表空间需要用到,该路径不唯一,根据目标数据库存放数据文件位置而定。

[oracle@orac ~]$ /home/oracle/app/oradata [oracle@orac ~]$ mkdir snail

  ②登录数据库

(注意/与as之间要有空格)[oracle@orac ~]$ sqlplus / as sysdba

执行sql语句

SQL> select a.tablespace_name,a.bytes/1024/1024 "sum MB", (a.bytes-b.bytes)/1024/1024 "used MB",b.bytes/1024/1024 "free MB",round (((a.bytes-b.bytes)/a.bytes)*100,2) "used%" from (select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a, (select tablespace_name,sum(bytes) bytes,max (bytes) largest from dba_free_space group by tablespace_name)b where a.tablespace_name=b.tablespace_name order by ((a.bytes-b.bytes)/a.bytes) desc;

即可得到当前数据库的表空间情况,如下图:

  也可以通过第三方工具登录数据库执行上述sql语句(以下几步也同样可以) 

注: 如果要导入的数据库表空间名与当前已有表空间名相同,则无需新建表空间(也不可以再建),但是必须确定已有表空间大小充足,或者已经设置为自动增加并且自动增加的最大值足够大,那么就不需要进行表空间扩充,直接使用该表空间级即可,跳过第四步。

 反之如果没有该名称的表空间,或者表空间大小不足以存放要导入的数据时,需要对该表空间进行扩充,执行第四步。

4. 表空间扩充

 对表空间进行扩充有多种方法,简单介绍其中几个常用方法: 

① 直接增大表空间的大小:   

先查看表空间中数据文件存放的位置

SQL> select tablespace_name, file_id, file_name, round(bytes/(1024*1024),0) total_space from dba_data_files order by tablespace_name;

 确定数据文件位置后,执行命令: 

 alter database datafile ‘数据文件路径' resize 要增大的大小 

 例如:

SQL> alter database datafile '/home/oracle/oradata/SPS_DATA.DBF' resize 4000m

 ③ 设置表空间自动扩展  alter database datafile ‘要扩展地表空间' autoextend on next 扩展单元大小 maxsize 最大扩展大小  

例如:

SQL> alter database datafile '/home/oracle/app/oradata/snail/SPS_DATA.dbf' autoextend on next 100m maxsize 10000m

备注:方法可以结合使用,尤其当不确定导入文件最终大小时建议使用,如:

SQL> alter tablespace SPS_DATA add datafile '/home/oracle/app/oradata/snail/SPS_DATA02.dbf' size 2000m autoextend on next 200M maxsize 12000M;

对表空间扩充之后可再次执行3.步中查看表空间大小的sql,确认表空间扩充成功。

5. 创建临时表空间与数据表空间

 创建用户前必须要先创建临时表空间和数据库表空间两个表空间,否则用系统默认的表空间,会引起其他问题。 

①创建临时表空间  create temporary tablespace 临时表空间名 tempfile ‘临时表空间位置' size 临时表空间大小autoextend on next 100m maxsize 10240m extent management local;   

例如:

SQL> create temporary tablespace SPS_DATA_temp tempfile'/home/oracle/app/oradata/snail/SPS_DATA_temp.dbf' size 1024m autoextend on next 100m maxsize 10240m extent management local;

 ②创建数据表空间 

 参数大致同创建临时表空间 

 例如:

SQL> create tablespace SPS_DATA logging datafile'/home/oracle/app/oradata/snail/SPS_DATA01.dbf' size 1024m autoextend on next 100m maxsize 10240m extent management local;

6. 创建数据库用户并指定表空间

  该用户用于管理即将导入的数据,导入时也切换到该用户进行导入操作(如果用imp命令进行导入,最好此用户名与导出时采用的用户名为同样的用户名,不同的话可能还需要做映射),格式为:  

create user 用户名identified by 用户密码default tablespace 所指定的表空间名 temporary tablespace 临时表空间名;  

例如:

SQL> create user abc identified by ABC default tablespace SPS_DATA temporary tablespace SPS_DATA_temp;

7. 赋予用户权限

 因为要用该用户进行导入操作,故应给予用户的权限至少包括dba、IMP_FULL_DATABASE权限,也有人建议应与导出数据库数据时用户的权限一致。 

授权sql:(视具体情况而定)

grant dba,imp_full_database,exp_full_database,connect,resource,create session to 用户名;

 例如:

SQL> grant create user,drop user,alter user ,create any view ,drop any view,exp_full_database,imp_full_database,dba,connect,resource,read,write,create session to abc;

二、采用exp/imp命令

知识扩充: 数据泵导出导入(EXPDP和IMPDP)的作用 

1、实现逻辑备份和逻辑恢复。  

2、在数据库用户之间移动对象。  

3、在数据库之间移动对象  

4、实现表空间搬移。 

数据泵导出导入与传统导出导入的区别:  在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP.使用EXPDP和IMPDP时应该注意的事项: 

EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务器端使用。 

EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用 

IMP只适用于EXP导出文件,不适用于EXPDP导出文件;IMPDP只适用于EXPDP导出文件,而不适用于EXP导出文件。

1. 导出命令

 导出与导入分别都有三种方式: ①完全模式导出(导入):  将整个数据库内容导出,但是操作时需要有特殊权限,  exp 用户名/密码buffer=32000file=导出的目录 full=y   例如:

exp system/manager buffer=32000 file=d:iom.dmp full=yexp system/manager buffer=32000 file=d:iom.dmp full=y

 ②用户模式导出(导入) 

 将指定用户的所有对象进行导出,例如:

exp iom/iom  buffer=32000 file=d:iom.dmp owner=iom exp iom/iom buffer=32000 file=d:iom.dmp owner=iom

 ③表模式导出(导入)  

将用户的所有表数据进行导出,例如:

exp iom/iom  buffer=32000 file=d:iom.dmp owner=iom tables=(iom)exp iom/iom buffer=32000 file=d:iom.dmp owner=iom tables=(iom)

 备注:可以执行exp help=y、imp help=y查看帮助命令,以及执行exp或者imp查看对应版本号。

 导出步骤: 首先切换到oracle用户(数据库超级管理员)

[oracle@orac ~]$ su - oracle [oracle@orac ~]$ su - oracle

 根据所需要采用的导出模式进行导出

[oracle@orac~]$exp iom/iom file=iom.dmp log=oradb.log full=y compress=y direct=y [oracle@orac~]$exp iom/iom file=iom.dmp log=oradb.log full=y compress=y direct=y

  COMPRESS参数将在导出的同时合并碎块,尽量把数据压缩到initial的EXTENT里,默认是N,一般建议使用。DIRECT参数将告诉EXP直接读取数据,而不像传统的EXP那样,使用SELECT来读取表中的数据,这样就减少了SQL语句处理过程。一般也建议使用。不过有些情况下DIRECT参数是无法使用的。 其他参数可参照帮助命令,或者其他资料进行学习。在此不一一赘述。

2. 导入命令

 登录服务器,切换到oracle用户。

[oracle@orac ~]$ su - oracle[oracle@orac ~]$ su - oracle

 执行导入命令:  

导入时需要用准备工作中创建的新用户,如:用户名abc,密码ABC   imp 用户名/密码 file=dmp文件路径 log=输出日志路径full=y ignore=y;  

 例如:

[oracle@orac ~]$imp abc/ABC file=/home/oracle/iom.dmp log=/home/oracle/iom.log full=y ignore=y;[oracle@orac ~]$imp abc/ABC file=/home/oracle/iom.dmp log=/home/oracle/iom.log full=y ignore=y;

 温馨提示:采用数据泵导入过程经常会遇到问题,建议多查阅资料,总有方法解决。相信每一件事物都有它存在的必要性,问题只是暂时的,成功才是必然的!

三、采用第三方工具(以PLSQL为例)

1. 导出格式介绍

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

② Sql格式:.sql格式的文件,可用文本编辑器查看,通用性比较好,效率不如第一种,适合小数据量导入导出。尤其注意的是表中不能有大字段(blob,clob,long),如果有,会报错 

③ Pde格式:.pde格式的文件,.pde为PL/SQL Developer自有的文件格式,只能用PL/SQL Developer工具导入导出,不能用文本编辑器查看。 

备注: 虽然dmp格式为最优选,但是不容易实现,原因有两点:首先此格式需要安装oracle完整版,因为导出时需要选择对应exp.exe与imp.exe,而且导出时安装的版本要与要导出数据的数据库版本一致,同理导入时也要对应,否则会出现版本不一致的问题(查阅资料中介绍的,个人没有证实);其次此格式的导出经常会遇到导出过程一闪而过,但是导出不成功的情况,原因未知(可以查阅环境变量配置ORACLE_HOME配置正确,个人尝试多次,仍有问题,最后无奈选取导出为pde格式)。

2. 导出方法

登录plsql工具,所使用用户为源数据库有导出权限(exp_full_database,dba等)的用户。 ①导出建表语句(包括存储结构) 导出步骤tools ->export user object,选择要导出的对象,导出.sql文件,如下图:

等待导出完成

 ②导出数据文件  

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

导出为dmp格式,如下图:

导出为sql格式,如下图: 

导出为pde格式,如下图: 

备注:采用第三方工具导出导入整个数据库的话,耗时较长,一定要有足够的时间来操作(数据量大的话需要好几个小时)

3. 导入方法

登录plsql工具,使用之前准备工作所创建的用户。 

步骤类似导出方法 

①导入建表语句  

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

②导入数据  

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

备注:导入之前最好把以前的表删除,当然导入另外数据库除外。     

另外导入时当发现进度条一直卡在一个点,而且导出的文件不再增大时,甚至是提示程序未响应,千万不要以为程序卡死了,这个导入导出就是比较缓慢,只要没有提示报错,或者导入完成就不要停止程序。

参考文献:

Oracle - 数据库的实例、表空间、用户、表之间关系: 

http://www.cnblogs.com/adforce/p/3312252.html

2.PL/SQL Developer导入导出数据库方法: 

http://jingyan.baidu.com/article/d5a880eb69ff7313f047cc5f.html

3.linux下创建oracle表空间: 

http://blog.sina.com.cn/s/blog_62192aed01018aep.html

4.plsql连接64位数据库及plsql导出表闪现错误:

http://201405221449.iteye.com/blog/2241714

5.oracle安装包官网下载: 

http://www.oracle.com/technetwork/topics/winsoft-085727.html

6.ORACLE 表空间扩展方法:

http://www.jb51.net/database/201110/109669.html

7.Exp/imp命令详解:

http://blog.csdn.net/caijing3210/article/details/7528788  

http://www.cnblogs.com/yugen/archive/2010/07/25/1784763.html  http://www.cnblogs.com/whsa/p/3975817.html

到此这篇关于浅谈入门级oracle数据库数据导入导出步骤的文章就介绍到这了,希望对大家的学习有所帮助,也希望大家多多支Python之眼。

最后:

小编是一名python开发工程师,这里有我自己整理了一套最新的python系统学习教程,包括从基础的python脚本到web开发、爬虫、数据分析、数据可视化、机器学习等。想要这些资料的可以关注小编,并在后台私信小编:“01”即可领取。非诚勿扰!

oracle临时表经常被锁_这是一篇长篇入门级数据库讲解:oracle数据库数据导入导出步骤相关推荐

  1. cmd imp导入dmp文件_这是一篇长篇入门级数据库讲解:oracle数据库数据导入导出步骤...

    正如标题一样,本文内容主要介绍了浅谈入门级oracle数据库数据导入导出步骤,文章通过步骤解析介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧!!! ...

  2. oracle数据库数据导入导出步骤(入门)

    oracle数据库数据导入导出步骤(入门) 说明:  1.数据库数据导入导出方法有多种,可以通过exp/imp命令导入导出,也可以用第三方工具导出,如:PLSQL  2.如果熟悉命令,建议用exp/i ...

  3. oracle 加载数据戽_oracle数据库数据导入导出步骤(入门)

    oracle数据库数据导入导出步骤(入门) 说明: 1.数据库数据导入导出方法有多种,可以通过exp/imp命令导入导出,也可以用第三方工具导出,如:PLSQL 2.如果熟悉命令,建议用exp/imp ...

  4. oracle数据库数据导入导出步骤

    oracle数据库数据导入导出步骤(基础) 前言: Oracle Database,又名Oracle RDBMS,或简称Oracle.是甲骨文公司的一款关系数据库管理系统.它是在数据库领域一直处于领先 ...

  5. oracle临时表经常被锁_数据库学习——Oracle 数据库了解与使用

    一. 数据库相关概念 1 什么是数据库 所谓的数据库其实就是数据的集合.用户可以对集合中的数据进行新增.查询.更新.删除等操作.数据库是以一定方式储存在一起.能与多个用户共享.具有尽可能小的冗余度.与 ...

  6. oracle临时表经常被锁_【赵强老师】Oracle数据库的存储结构

    Oracle的存储结构分为:物理存储结构和逻辑存储结构. 一.物理存储结构:指硬盘上存在的文件 数据文件(data file) 一个数据库可以由多个数据文件组成的,数据文件是真正存放数据库数据的.一个 ...

  7. Oracle数据库的创建、数据导入导出

    如何结合Sql脚本和PL/SQL Developer工具来实现创建表空间.创建数据库.备份数据库.还原数据库等操作,然后实现Oracle对象创建.导入数据等操作,方便我们快速了解.创建所需要的部署Sq ...

  8. oracle备份密码文件,[数据库]Oracle数据库备份dmp文件,使用cmd命令导入导出步骤,以及忘记Oracle密码_星空网...

    Oracle数据库备份dmp文件,使用cmd命令导入导出步骤,以及忘记Oracle密码 2013-07-30 0 dmp文件导入导出步骤 1.创建表空间 --datafile 的路径随便给,但是后面的 ...

  9. oracle sql 导入mysql数据库备份_使用PL/SQL连接oracle数据库,并将数据进行导出备份和导入恢复...

    使用PL/SQL连接oracle数据库,并将数据进行导出备份和导入恢复 这种操作百度一搜一大片,今天整理以前做的项目时自己备份了一下数据库,试着将数据进行导出备份和导入恢复了一下:下面是操作过程: 1 ...

最新文章

  1. 【Paper】2016_Cooperative UAV-UGV modeled by Petri Net Plans specification
  2. matlab上机实验报告,MATLAB上机实验
  3. 域名服务商GoDaddy第四季度扭亏为盈
  4. java递归空瓶换饮料_问题描述:一次买n瓶可乐,k个空瓶可以换一瓶饮料,那么一共能喝多少瓶饮料? | 学步园...
  5. python模拟页面调度LRU算法
  6. Grafana、M3DB、Prometheus 集成 关于M3DB集成的文章本就不多,快来瞅瞅吧!!!说不定有用呢?
  7. power bi指标呈现_在Power BI中使用关键绩效指标
  8. 好铁不打钉,好男不当网管-----论网管的自我修养 ...
  9. aauto的listview(类似于C#的datagrid) 支持文件拖拽获取名单
  10. 【IIS】修改注册表键值提升IIS的性能
  11. 排列怎么用计算机计算公式,数学排列组合公式计算器
  12. dubbo配置timeout
  13. 电脑使用手机摄像头(超详细)
  14. 一份超详细的Spring4常用知识清单!
  15. 51cto python数据分析系列课程 55g_Python 3 数据分析与挖掘系列课程完整版
  16. Kali linux破解Wi-Fi
  17. tkinter模块 视窗设计相关操作
  18. windows创建文件硬连接
  19. 全球及中国口腔医疗行业投融资现状与与运营效益分析报告2022版
  20. 【C语言进阶】带你深度剖析那些常见的字符函数(一)

热门文章

  1. Http Post 二进制通信
  2. Citrix Xendesktop5中创建虚拟机失败的2个案例分析
  3. 2011 端午后,杭州支付宝
  4. 参加了博客园北京俱乐部4月4日的活动-Nice
  5. 京东购物车双11实战
  6. python微信头像_转:20行Python代码给微信头像戴帽子
  7. atheros无线网卡驱动_5.8G无线网桥CPE,安防监控拍档高清无干扰
  8. vsn服务器 需要先建项目才能,急求!项目马上上线,但是Oracle服务器存在问题...
  9. PaddleOCR-release-2.3\deploy\cpp_infer\src识别中文时出现乱码
  10. PaddleOCR问题汇总(1)