分享一次Oracle数据导入导出经历
最近工作上有一个任务要修改一个比较老的项目,分公司这边没有这个项目数据库相关的备份,所以需要从正式环境上面导出数据库备份出来在本地进行部署安装,之前在其它项目的时候也弄过这个数据库的部署和安装,也写了一个操作文档,但是写的不是那么的详细,很多场景都没有考虑到,后面想了想还是重新写一个操作文档方便下次数据库相关导出的操作,也同时能够帮助其它初次接触的同事快速操作。
项目的采用的开发相关是: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数据导入导出经历的更多相关文章
- oracle数据导入/导出
Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据 ...
- Oracle数据导入导出
Oracle数据导入导出imp/exp 在oracle安装目录下有EXP.EXE与IMP.EXE这2个文件,他们分别被用来执行数据库的导入导出.所以Oracle数据导入导出imp/exp就相当与ora ...
- Oracle数据导入导出imp/exp
功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢失). Oracle有个好处,虽然你的电 ...
- Oracle数据导入导出imp/exp sp2-0734:未知的命令开头'imp...解决方法
Oracle数据导入导出imp/exp sp2-0734:未知的命令开头'imp...解决方法 sp2-0734:未知的命令开头'imp 忽略了剩余行默认分类 www.2cto.com 应该 ...
- Oracle数据导入导出imp/exp(转)
在oracle安装目录下有EXP.EXE与IMP.EXE这2个文件,他们分别被用来执行数据库的导入导出.所以Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 一.Oracle ...
- Oracle 数据导入导出操作 (转)
Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢 ...
- Oracle数据导入导出imp/exp命令 10g以上expdp/impdp命令
Oracle数据导入导出imp/exp就相当于oracle数据还原与备份.exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处的数据库服务器中. 利 ...
- Oracle数据导入导出命令
IMP 和EXP命令 Oracle数据导入导出imp/exp就相当于oracle数据还原与备份.exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处 ...
- oracle数据导入/导出(2)
Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢 ...
随机推荐
- CPU最核心的电子元件叫做石英晶振
CPU是电子计算机的主要设备之一,是电脑中的核心配件.主要功能是解释计算机指令以及处理计算机软件中的数据.有人会问,你知道CPU里面都有什么吗?我想大家都会说硅晶体,集成度极大的半导体材料.却没有人提 ...
- 使用wamp扩展php时出现服务未启动的解决方法
今天在使用wamp扩展php的插件时,出现了如下图所示的错误提示 网上查了查,都说是端口原因,修改Apache的 80端口,但是并没有解决问题. 最后我终于找到了解决方法,步骤很简单,如下: 首先,在 ...
- python基础入门教程《python入门经典》
第一章 在python中使用数字 1.用变量存储信息 1.1变量的类型 变量,用于存储很多不同的数据类型的信息. 基本数据类型 数据类型 存储内容 示例 integer 整 float 浮点 ...
- SDWebImage源码阅读-第一篇
一 题外话 之前写过一篇最新版SDWebImage的使用,也简单的介绍了一下原理.这两天正梳理自己的知识网络,觉得有必要再阅读一下源码,一是看具体实现,二是学习一下优秀开源代码的代码风格,比如接口设计 ...
- Dojo初探之2:设置dojoConfig详解,dojoConfig参数详解+Dojo中预置自定义AMD模块的四种方式(基于dojo1.11.2)
Dojo中想要加载自定义的AMD模块,需要先设置好这个模块对应的路径,模块的路径就是这个模块的唯一标识符. 一.dojoConfig参数设置详解 var dojoConfig = { baseUrl: ...
- github pages部署静态网页
如果你的项目只是一个静态网站,就没有必要再去整什么服务器,github pages 提供了搭建静态网站的功能: 为什么使用Github Pages 1. 搭建简单而且免费: 2. 支持静态脚本: 3. ...
- 用户权限模块之oauth2.0
主要是在springsecurity上面扩展即可,所以内容也是基于上一个, sql: CREATE TABLE `auth_access_token` ( `id` int(11) NOT NULL ...
- 带着问题写React Native原生控件--Android视频直播控件
最近在做的采用React Native项目有一个需求,视频直播与直播流播放同一个布局中,带着问题去思考如何实现,能更容易找到问题关键点,下面分析这个控件解决方法: 现在条件:视频播放控件(开源的ijk ...
- solr学习笔记-开篇
由于工作需要,近期接触了一下全文检索的相关技术,从lucenen到solr开始慢慢一路摸爬滚打,仅以此文记录自己的学习里程和记录下各种坑. 本次学习基于以下环境版本: java7,solr5.5.4( ...
- Linux版微信
一.到github上下载https://github.com/geeeeeeeeek/electronic-wechat/releases下载linux-x64.tar.gz,具体根据操作系统是32位 ...