使用PLSQL-Developer工具可以快速便捷地完成Oracle数据库用户、表的备份恢复。

Oracle数据库用户数据完整备份与恢复

1. 备份

1.1   PL/SQL->工具->导出用户对象,选项如图

常用的用户对象包括:

TABLE,SEQUENCE,VIEW,PACKAGE,TYPE,FUNCTION,PROCEDURE,PACKAGE BODY,TREGGER

选择需要导入的用户对象,导出.sql文件,此步骤导出的是建表语句,包括存储过程、触发器、视图等 。

1.2  PL/SQL->工具->导出表,选项如图

按ctrl键选择需要导出的所有对象

上一步中导出的表中没有数据,所以这一步是要导出表中的所有数据(选择PL/SQL Developer方式。另外两种方式Oracle导出、SQL插入后边再介绍)

至此,备份完成,通常SQL文件大也只有几兆,PDE文件有上百兆。

2.恢复

2.1   由于上面我们导出的是一个用户下完整的数据,所以如果要恢复的数据库里面有这个用户,我们首先执行删除用户及用户下所有数据的操作,并结束相关进程,脚本如下:

drop user username cascade;

select sid,serial# from v$session where username='username';

alter system kill session sessionID;

说明:如果要把备份还原到其它数据库上,则不需要做上面的操作。

2.2   创建用户并赋予权限,脚本如下:

说明:要创建用户自己的数据表空间及临时表空间

CREATE USER username IDENTIFIED BY 12345678 DEFAULT TABLESPACE test_data TEMPORARY TABLESPACE test_temp;

Grant create session to username;
grant connect to username with admin option; 
grant resource to username with admin option;
-- Grant/Revoke system privileges
grant alter any role to username; 
grant alter any sequence to username; 
grant alter any table to username; 
grant alter any trigger to username; 
grant alter tablespace to username; 
grant comment any table to username; 
grant create any sequence to username; 
grant create any table to username; 
grant create any trigger to username; 
grant create any view to username; 
grant create materialized view to username with admin option; 
grant create public synonym to username with admin option; 
grant create role to username; 
grant create session to username with admin option; 
grant create synonym to username with admin option; 
grant create tablespace to username; 
grant create user to username; 
grant create view to username with admin option; 
grant drop any role to username; 
grant drop any sequence to username; 
grant drop any table to username; 
grant drop any trigger to username; 
grant drop tablespace to username; 
grant drop user to username; 
grant grant any role to username; 
grant insert any table to username; 
grant select any table to username; 
grant unlimited tablespace to username with admin option; 
grant update any table to username;

2.3   打开一个命令窗口,将备份好的SQL文本内容复制到命令窗口执行,这一步是创建所有的用户对象,包括表,存储过程,函数,序列…… 但是此时表中是没有数据的

2.4   导入表

在PL/SQL->工具->导入表(按ctrl键选择需要导入的表)

将会依次执行 禁止所有触发器,禁止所有外键约束,删除所有表数据,插入所有表数据,启用外键约束,启用触发器的操作。导入用户对象通常几分钟就能解决,导入表中的数据通常要几十分钟甚至几个小时。

=======================

PLSQL工具导出表时三种导出方式说明:

PL/SQL工具导出表时包含三种方式导出Oracle表结构及数据,三种方式分别为:Oracle Export (客户端exp工具)、SQL Inserts、PL/SQL Developer,下面分别简单介绍下区别:

第一种方式是导出.dmp格式的文件,.dmp是二进制文件,可跨平台,还能包含权限,效率不错,用的最为广泛。跟exp/imp工具进行导入导出方式一致。http://www.cnblogs.com/rusking/p/4006166.html

第二种方式导出.sql格式的insert into 脚本,可用文本编辑器查看,通用性比较好,效率不如第一种,适合小数据量导入导出。尤其注意的是表中不能有大字段(blob,clob,long),如果有,会提示不能导出(提示如下: table contains one or more LONG columns cannot export in sql format,user Pl/sql developer format instead)。

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

导入数据时,也有以上三种导出方式对应的导入方式:

原文链接:http://www.cnblogs.com/Acamy/p/5893724.html

Oracle数据库用户数据完整备份与恢复的更多相关文章

  1. Oracle数据库---用户与角色

    Oracle数据库---用户与角色 2019年02月26日 10:56:10 俊杰梓 阅读数:21 标签: 数据库 更多 个人分类: 数据库   版权声明:版权所有,转载请注明出处.谢谢 https: ...

  2. 简便删除已经存在的oracle数据库用户UPAY3LINGXI_YS

    简便删除已经存在的oracle数据库用户UPAY3LINGXI_YS:1.Toad工具用oracle最大权限用户登录system2.查看正在使用UPAY3LINGXI_YS的进程select * fr ...

  3. Oracle 数据库用户管理

    Oracle 数据库用户管理 Oracle 权限设置      一.权限分类: 系统权限:系统规定用户使用数据库的权限.(系统权限是对用户而言). 实体权限:某种权限用户对其它用户的表或视图的存取权限 ...

  4. oracle数据库删除数据Delete语句和Truncate语句的对比

    oracle数据库删除数据Delete语句和Truncate语句的对比 当表中的数据不需要时,则应该删除该数据并释放所占用的空间,删除表中的数据可以使用Delete语句或者Truncate语句,下面分 ...

  5. 删除oracle数据库用户

    手工删除ORACLE数据库用户时常会出现会话进程仍在使用导致删除失败的情况.需要查询会话并将会话删除才能成功将数据库用户删除,比较不方便. 适用场景 自动删除oracle数据库用户 基本知识 orac ...

  6. Linux删除ORACLE数据库用户失败提示ORA-01940解决方法

    操作环境 SuSE11+Oracle11gR2 问题现象 删除ORACLE数据库用户失败,提示ORA-01940: cannot drop a user that is currently conne ...

  7. spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置

    spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...

  8. C#连接Oracle数据库查询数据

    C#连接Oracle数据库可以实现许多我们需要的功能,下面介绍的是C#连接Oracle数据库查询数据的方法,如果您对C#连接Oracle数据库方面感兴趣的话,不妨一看. using System; u ...

  9. sql developer Oracle 数据库 用户对象下表及表结构的导入导出

    Oracle数据库表数据及结构的导入导出   导出的主机与即将导入到的目标主机的tablespace 及用户名需一直!!!!!

随机推荐

  1. PHP之验证码识别

    首先推荐几篇有关验证码识别的文章,觉得不错 php实现验证码的识别(初级篇) 关于bp神经网格识别验证码 一.思路 碰见一个验证码,如果我们想要识别它,我们需要的是做什么呢? 我们先观察几个验证码.. ...

  2. VS2010 release 和 debug 调试区别

    VC下Debug和Release区别 最近写代码过程中,发现 Debug 下运行正常,Release 下就会出现问题,百思不得其解,而Release 下又无法进行调试,于是只能采用printf方式逐步 ...

  3. STM32学习笔记——定时器中断(向原子哥学习)

    定时器中断 STM32 的定时器功能十分强大,有 TIME1 和 TIME8 等高级定时器,也有 TIME2~TIME5 等通用定时器,还有 TIME6 和TIME7 等基本定时器.在本章中,我们将利 ...

  4. ibatis 环境搭建(1)

    目录和jar包

  5. 转:关于数据库压缩技术的Survey

    原文来自于:http://outofmemory.cn/mysql/database-compression-tech 昨天给团队内的小伙伴做了一个关于数据库压缩技术的Survey,现将其中可以公开的 ...

  6. jQuery折叠风琴

    这个效果用jQuery做是很方便的,根本不需要搞得很复杂. 网上有些效果DEMO不仅用了jQuery还引用一两个封装文件,真是匪夷所思. 最初想到了toggle: jQuery(document).r ...

  7. varnish、squid、apache、nginx缓存的对比<转>

    1.Squid,很古老的反向代理软件,拥有传统代理.身份验证.流量管理等高级功能,但是配置太复杂.它算是目前互联网应用得最多的反向缓存代理服务器,工作于各大古老的cdn上. 2.Varnish是新兴的 ...

  8. 【HDOJ】2371 Decode the Strings

    快速矩阵乘法.注意,原始字符串即为decode后的字符串.题目是要找到原始串. #include <cstdio> #include <cstring> #define MAX ...

  9. 【算法Everyday】第三日 KMP算法

    题目 你知道的. 分析 分析不来. 代码 void OutputArray(int* pArr, int iLen) { ; i < iLen; i++) { printf("%d\t ...

  10. (转载)PHP使用empty检查函数返回结果时报Fatal error: Can't use function return value in write context的问题

    (转载)http://be-evil.org/post-153.html PHP开发时,当你使用empty检查一个函数返回的结果时会报错:Fatal error: Can't use function ...