最近工作上有一个任务要修改一个比较老的项目,分公司这边没有这个项目数据库相关的备份,所以需要从正式环境上面导出数据库备份出来在本地进行部署安装,之前在其它项目的时候也弄过这个数据库的部署和安装,也写了一个操作文档,但是写的不是那么的详细,很多场景都没有考虑到,后面想了想还是重新写一个操作文档方便下次数据库相关导出的操作,也同时能够帮助其它初次接触的同事快速操作。

项目的采用的开发相关是:Vs2008,Oracle 11g,PLSQL。

第一步,数据库的导出

a.数据库用户导出

1.查询所有数据库用户

 SELECT wm_concat(T.username)
FROM DBA_USERS T
WHERE T.account_status = 'OPEN'
AND T.default_tablespace NOT IN ('SYSTEM', 'SYSAUX')
AND T.username NOT IN ('SCOTT','EMULATION')

2.导出创建表空间及数据文件脚本

 SELECT 'CREATE TABLESPACE ' || T.TABLESPACE_NAME ||
' DATAFILE ''E:\ORADATA\FSDB\' || T.TABLESPACE_NAME || '01.DBF'' size 100M autoextend on;'
FROM DBA_TABLESPACES T
WHERE T.TABLESPACE_NAME NOT IN
('SYSTEM', 'SYSAUX', 'UNDOTBS1', 'TEMP', 'USERS', 'UNDOTBS2');

E:\ORADATA\FSDB\  本地数据库文件存储目录

会查询出类似以下脚本

CREATE TABLESPACE TBS_TYUM_SMS DATAFILE 'E:\ORADATA\FSDB\TBS_TYUM_SMS01.DBF' size 100M autoextend on;

TBS_TYUM_SMS   表空间名称

E:\ORADATA\FSDB\TBS_TYUM_SMS01.DBF   创建的空间表DBF文件

3.创建导出文件相关操作

一、创建导出文件存放的文件目录(该目录必须存在),该命令不会在操作系统创建真正的目录,最好以system等管理员创建。

create or replace directory DPDATAGGDB as 'E:\backup\xxxx';

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

select * from dba_directories;

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

grant read,write on directory DPDATAGGDBto scott;

4.按用户导出

-按用户导出

Expdp system/123456@XXDB schemas=xxxx dumpfile=XXDB20170307BAK.DMP directory=DPDATAGGDB  logfile=XXDB20170307BAK.log

-exp全部导出

exp system/123456@XXDB  file=E:\backup\xxxx\QZDB20170220_bak.dmp full=y

system/123456   登录dba账号密码

XXDB      需要导出的数据库名称

schemas    用户集合

dumpfile=XXDB20170307BAK.DMP   导出的数据dmp文件

directory=DPDATAGGDB   第三部创建的文件目录  这里导出的文件会在该目录下面生成对应文件

logfile=XXDB20170307BAK.log      导出的数据log文件

第二步,数据库导入

1.01打开oracle Databese配置工具

1.02进入欢迎页面

1.03选择创建数据库,如果需要修改可以选择配置数据库选件

1.04数据库模板

1.05填写数据库连接表示

1.06管理选项,可直接下一步

1.07填写数据库登录信息,为了管理方便选择所要账号使用同一管理口令

1.08设置数据文件存放位置,可选择默认位置,也可自己设置存放位置

1.09设置恢复配置,可选择默认数据

1.10数据库内容,可跳过

1.11初始化参数,主要分配内存空间,需要考虑当前服务器上面可用空间,多个数据库需要平均处理,后面的调整大写,字符集,链接模式可以选择默认选项

1.12数据库存储

1.13创建选项

1.14点击完成就会生成数据库了

2.打开PLSQ或者TOAD用sys  DBA身份登录创建第一步第二个操作导出

CREATE TABLESPACE TBS_TYUM_SMS DATAFILE 'E:\ORADATA\FSDB\TBS_TYUM_SMS01.DBF' size 100M autoextend on;

.....这里应该导出多个空间的创建语句

3.创建用于导入导出的文件目录

create or replace directory TY_DUMP_DIR as 'E:\app '

E:\app 必需是已经存在的目录。

查看已经存在的目录

select * from dba_directories

删除文件目录记录

DROP DIRECTORY TY_DUMP_DIR

用sys用户登录给要访问的用户指定访问目录的权限。

grant read,write on directory TY_DUMP_DIR to scott;

4.导入数据

Impdp SYSTEM/123456@XXDB directory=TY_DUMP_DIR dumpfile=XXDB20170307BAK.DMP  LOGFILE=XXDB20170307BAK.LOG full=y

impdp system/123456@XXDB schemas=xxxx dumpfile=XXDB20170307BAK.DMP directory=DPDATAGGDB logfile=XXDB20170307BAK.log

或者

imp system/123456@XXDB  file=d:\bak.dmp full=y ignore=y

这里的相关关键词不一一解释了,可以参照导出文件说明

如果是EXpdp 导出的则需要用Impdp 导出    EXP则需要用imp  不然会在导出的时候报错

这里所有的导入导出操作都要在cmd命令符操作下进行  window+R   cmd

其实在导入导出的过程中应该还会遇到其他的一些问题,这里因为之前在操作的时候没有记录了,以后如果碰到了问题,我会在这里一一记录,也希望这篇文章能够给需要的人带来帮助。如果有什么写错的地方也希望大家能够指出来。谢谢!

微信链接:链接

如果有感兴趣的可以关注一下。

分享一次Oracle数据导入导出经历的更多相关文章

  1. oracle数据导入/导出

    Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份.   大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据 ...

  2. Oracle数据导入导出

    Oracle数据导入导出imp/exp 在oracle安装目录下有EXP.EXE与IMP.EXE这2个文件,他们分别被用来执行数据库的导入导出.所以Oracle数据导入导出imp/exp就相当与ora ...

  3. Oracle数据导入导出imp/exp

    功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢失). Oracle有个好处,虽然你的电 ...

  4. Oracle数据导入导出imp/exp sp2-0734:未知的命令开头'imp...解决方法

    Oracle数据导入导出imp/exp sp2-0734:未知的命令开头'imp...解决方法   sp2-0734:未知的命令开头'imp 忽略了剩余行默认分类   www.2cto.com  应该 ...

  5. Oracle数据导入导出imp/exp(转)

    在oracle安装目录下有EXP.EXE与IMP.EXE这2个文件,他们分别被用来执行数据库的导入导出.所以Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 一.Oracle ...

  6. Oracle 数据导入导出操作 (转)

    Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢 ...

  7. Oracle数据导入导出imp/exp命令 10g以上expdp/impdp命令

    Oracle数据导入导出imp/exp就相当于oracle数据还原与备份.exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处的数据库服务器中. 利 ...

  8. Oracle数据导入导出命令

    IMP 和EXP命令 Oracle数据导入导出imp/exp就相当于oracle数据还原与备份.exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处 ...

  9. oracle数据导入/导出(2)

    Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢 ...

随机推荐

  1. SSH实现无密码验证登录

    http://blog.csdn.net/houqd2012/article/details/8544517

  2. DelayQueue使用

    假设现有如下的使用场景: a) 关闭空闲连接.服务器中,有很多客户端的连接,空闲一段时间之后需要关闭之. b) 缓存.缓存中的对象,超过了空闲时间,需要从缓存中移出. c) 任务超时处理.在网络协议滑 ...

  3. 编写原生的Node.js模块

    导语:当Javascript的性能遭遇瓶颈,或者需要增强Javascript能力的时候,就需要依赖native模块来实现了. 应用场景 日常工作中,我们经常需要将原生的Node.js模块做为依赖并在项 ...

  4. Dojo初探之3:dojo的DOM操作、query操作和domConstruct元素位置操作(基于dojo1.11.2版本)

    前言: 前面两章讲了dojo的基本规范和配置,当然这个配置不是必须的,当你有这需求的时候就可以用到dojo的config配置. dojo的所有js都是符合AMD规范进行异步加载的:http://blo ...

  5. WLAN高密无线网络部署的信道问题

    WIFI信号的信道有两部分,其中2.4G频段有13个左右交叠的信道(14信道只在日本使用),其中只能找出3个相互不重合的信道(具体请参考文末的链接),最常用的就是1.6.11这三个,当然也可以使用其他 ...

  6. Webpack 资源管理

    Webpack 资源管理

  7. phantomjs-prebuilt@2.1.14 install: `node install.js`

    在用vue-cli构建项目时,npm install 安装包的时候报错了. 错误信息: npm ERR! Failed at the phantomjs-prebuilt@2.1.14 install ...

  8. java知识点整理

    1 java 和Tomcat总结 脑图地址  (其中web 容器部分还需要继续完善,但是没找到相关文档) 跟着java Se 文档梳理了一下学习路线图(方便全面掌握要点,及时对自己查漏补缺),以及一些 ...

  9. Tenacity——Exception Retry 从此无比简单

    Python 装饰器装饰类中的方法这篇文章,使用了装饰器来捕获代码异常.这种方式可以让代码变得更加简洁和Pythonic. 在写代码的过程中,处理异常并重试是一个非常常见的需求.但是如何把捕获异常并重 ...

  10. SQL Server2012数据库的备份和还原

    一.数据库的备份: 1.选择要备份的数据库“accountInfo”,点击鼠标右键 → 任务 → 备份 2.在打开的“备份数据库 —accountInfo”对话框中,先点击删除,然后点击“添加” 3. ...