Oracle数据库是企业级应用程序和数据库管理系统之一。在Oracle数据库中,表是一种常见的数据结构,它由列和行组成,存储着业务系统中的数据。然而,由于各种原因,表的数据可能会丢失、被破坏或不可用,这时就需要进行表恢复操作。本文将为您介绍如何进行Oracle数据库表恢复。
一、备份文件恢复
Oracle数据库表备份文件是一种保存表结构和数据的文件,既可以在外部媒介上存储,也可以在数据库内部存储。如果您在备份数据库表之前正确设置了备份参数,那么就可以使用备份文件恢复表。
步骤:
1. 连接到管理数据库的用户
连接SQL*Plus或SQL Developer到Oracle数据库,并以管理员身份登录。
2. 恢复表必需的备份文件
执行RMAN命令,恢复表必需的备份文件。命令示例:
RMAN> RESTORE TABLESPACE users;
RMAN> REPLACE TABLESPACE users;
3. 恢复表
执行IMP或IMPDP命令,恢复表。
IMP命令用于导入二进制文件,示例如下:
$ imp file=user.dmp touser=scott;
IMPDP命令用于导入导出数据泵文件,示例如下:
$ impdp directory=data_pump_dir dumpfile=user.dmp tables=scott.emp
这个命令将从数据泵文件夹”data_pump_dir”中导入名为”user.dmp”的表,并将其恢复到表“scott.emp”中。
二、闪回表
闪回表是Oracle数据库的一个特殊功能,它可以在不离线数据库的情况下,将数据库表恢复到一个特定时间点的状态。在应用程序中意外删除表数据或执行了错误的SQL语句时,都可以使用这个功能进行恢复。
步骤:
1. 查看要恢复的表
连接到SQL*Plus或SQL Developer,并使用SELECT语句查看要恢复的表。
2. 使用闪回功能对表进行恢复
根据前面查询得到的表名和表的逻辑和物理存储信息,请使用以下命令进行恢复:
ALTER TABLE emp FLASHBACK TABLE TO TIMESTAMP TO_DATE(‘2023-06-27 08:00:00′,’YYYY-MM-DD HH24:MI:SS’);
命令中,“emp”表示要恢复的表名,“TO TIMESTAMP”表示要恢复到的时间点,如“‘2023-06-27 08:00:00’”表示恢复到指定时间点。这里要注意表名的大小写,Oracle数据库区分大小写,如果表名大小写不正确,会导致恢复失败。
三、从其他库中恢复表
在Oracle数据库中,还可以从其他库中恢复表。
步骤:
1. 连接到源数据库
连接SQL*Plus或SQL Developer到源数据库,并以管理员身份登录。
2. 导出表
使用EXP或EXPDP命令导出表。示例如下:
$exp scott/tiger@orcl file=users.dmp tables=users
该命令将导出名为“users”的表数据到文件“users.dmp”中。
3. 连接到目标数据库
连接SQL*Plus或SQL Developer到目标数据库,并以管理员身份登录。
4. 导入表
使用IMP或IMPDP命令导入表。示例如下:
$imp scott/tiger@orcl file=users.dmp fromuser=scott touser=scott
该命令将在目标数据库中导入文件“users.dmp”中的表数据,从用户“scott”导入到用户“scott”。
结论
以上介绍了三种Oracle数据库表恢复方法,备份文件恢复、闪回表和从其他库恢复表。无论哪种方法,都需要在备份、恢复日期和时间点等设置上正确无误。一个健康的Oracle数据库对业务系统来说至关重要,因此,当出现表无法访问、数据丢失等情况时,使用Oracle表恢复功能确保数据库的重新启动和业务系统的连续性是非常必要和务实的做法。
相关问题拓展阅读:
- oracle数据库备份后怎么恢复
- oracle数据库怎么备份恢复
oracle数据库备份后怎么恢复
1 导出存储过程,触发器,序列等所有用户对象。(备份)
在PL/SQL Developer的菜物巧如单Tools(工具) => Export User Objects(导出用户对象)中出来一个对话框界面
建议红色框住部分都不选,这样执行这个sql 时,就根据当前你的登录账户来进行创建。 在对象列表中ctrl+a 全选所有(如果你只导出部分,可单独选择)
设置 输出文件地址,文件名。 点击导出完成。
2 导出数据。(备份)
在PL/SQL Developer的菜单Tools(工具) => 导出表 中出来一个对话框界面
如果 数据量较大,选择oracle导出,勾压缩选项,然后设置输出文件罩启地址。 如果只导出部分数据,可以在Where 处添加条件。例如 rownum 导入表 中出来一个对话框界面
可以在 “到用户” 处 选择你登录的账户。
b 如果是sql 格式文件,一样在PLSQL中新建一个命令窗口 (command windows) , 粘贴(ctrl+v) 刚才负责的sql内容。然后就开始自动执行还原了。
4 还原其他对象(存储过程,触发器,序列,函数等)
a. 用PLSQL 登录要还原的Oracle。此时你登录的账号是什么,还原就在该账号下。
b. 把先前备份的表结构sql文件打开,全选内容。 然后在PLSQL中新建一个命令窗口 (command windows) , 粘贴(ctrl+v) 刚才负责的sql内容。然后就开始自动执行还原了。
oracle数据库怎么备份恢复
一. 理解什么是数据库恢复
当桥游我们使用一个数据库时,总希望数据库的内容是可靠的、正确的,但由于计算机系统的故障(硬件故障、软件故障、网络故障、进程故障和系统故障)影响数据库系统的操作,影响数据库中数据的正确性,甚至破坏数据库,使数据库中全部或部分数据丢失。因此当发生上述故障后,希望能重构这个完整的数据库,该处理称为数据库恢复。恢复过程大致可以分为复原(Restore)与恢复(Recover)过程。
数据库恢复可以分为以下两类:
1.1实例故障的一致性恢复
当实例意外地(如掉电、后台进程故障等)或预料地(发出SHUTDOUM
ABORT语句)中止时出现实例故障,此时需要实例恢复。实例恢复将数据库恢复到故障之前的事务一致状态。如果在在线后备发现实例故障,则需介质恢复。在其它情况Oracle在下次数据库起动时(对新实例装配和打开),自动地执行实例恢复。如果需要,从装配状态变为打开状态,自动地激发实例恢复,由下列处理:
(1) 为了解恢复数据文件中没有记录的数据,进行向前滚。该数据记录在在线日志,
包括对回滚段的内容恢复。
(2) 回滚未提交的事务,按步1重新生成回滚段所指定的操作。
(3) 释放在故障时正在处理事务所持有的资源。
(4) 解决在故障时正经历一阶段提交的任何悬而未决的分布事务。
1.2介质故障或文件错误的不一致恢复
介质故障是当一个文件、一个文件的部分或磁盘不能读或不能写时出现的故障。文件错误一般指意外的错误导致文件被删除或意外事故导致文件的不一致。这种状态下的数据库都是不一致的,需要DBA手工来进行数据库的恢复,这种恢复有两种形式,决定于数据库运行的归档方式和备份方式。
(1) 完全介质恢复可恢复全部丢失的修改。一般情况下需要有数据库的备份且数据库运行在归档状态下并且有可用归档日志时才可能。对于不同类型的错误,有不同类型的完全恢复可使用,其决定于毁坏文件和数据库的可用性。
(2)
不完全介质恢复是在完全介质恢复不可能或不要求时进行的介质恢复。重构受损的数据库,使其恢复介质故障前或用户出错之前的一个事务一致性状态。不完全介质恢复有不同类型的使用,决定于需要不完全介质恢复的情况,有下列类型:基于撤消、基于时间和基于修改的不完全恢复。
基于撤消(CANCEL)恢复:在某种情况,不完全介质恢复必须被控制,DBA可撤消在指定点的操作。基于撤消的恢复地在一个或多个日志组(在线的或归档的)已被介质故障所破坏,不能用于恢复过程时使用,所以介质恢复必须控制,以致在使用最近的、未损的日志组于数据文件后中止恢复操作。
基于时间(TIME)和基于修改(SCN)的恢复:如果DBA希望恢复到过去的某个指定点,是一种理想的不完全介质恢复,一般发生在恢复到某个特定操腊源作之前,恢复到如意外删除某个数据表之前。
第二章. 数据库恢复案轮消态例测试环境
2.1 数据库环境
以下的所有案例都是通过测试经过,环境为:
OS:Windows 2023 Server
DB:Oracle 816
DBNAME:TEST
数据文件:
SQL> select file#,status,enabled,name from v$datafile;
FILE# STATUS ENABLED NAME
SYSTEM READ WRITE D:/Oracle/ORADATA/TEST/SYSTEM01.DBF
ONLINE READ WRITE D:/Oracle/ORADATA/TEST/RBS01.DBF
ONLINE READ WRITE D:/Oracle/ORADATA/TEST/USERS01.DBF
ONLINE READ WRITE D:/Oracle/ORADATA/TEST/TEMP01.DBF
ONLINE READ WRITE D:/Oracle/ORADATA/TEST/TOOLS01.DBF
ONLINE READ WRITE D:/Oracle/ORADATA/TEST/INDX01.DBF
控制文件:
SQL> select * from v$controlfile;
STATUS NAME
D:/Oracle/ORADATA/TEST/CONTROL01.CTL
D:/Oracle/ORADATA/TEST/CONTROL02.CTL
D:/Oracle/ORADATA/TEST/CONTROL03.CTL
联机日志:
SQL> select * from v$logfile;
GROUP# STATUS MEMBER
STALE D:/Oracle/ORADATA/TEST/REDO01.LOG
D:/Oracle/ORADATA/TEST/REDO02.LOG
STALE D:/Oracle/ORADATA/TEST/REDO03.LOG
2.2 数据库备份脚本
冷备份脚本:
rem script:coldbak.sql
rem creater:chenjiping
rem date:5.8.2023
rem desc:offline full backup database
–connect database
connect internal/password;
–shutdown database
shutdown immediate;
–Copy Data file
!xcopy d:/Oracle/oradata/test/*.dbf d:/database/H/R;
–Copy Control file
!xcopy d:/Oracle/oradata/test/*.ctl d:/database/H/R;
–Copy Log file
!xcopy d:/Oracle/oradata/test/*.log d:/database/H/R;
–startup database
startup;
说明:
1、以上脚本在数据库关闭状态下备份数据库所有的数据文件,联机日志,控制文件(在一个目
录下),如果成功备份,所有文件是一致的;
2、没有备份参数文件,参数文件可以另外备份,没有必要每次都备份,只需要在改变设置后备份一次;
3、如果以上命令没有成功依次执行,那么备份将是无效的,如连接数据库不成功,那么肯定关闭数据库也不成功,那么备份则无效;
4、冷备份建议下人工干预下执行。
数据库OS热全备份脚本
rem script:hotbak.sql
rem creater:chenjiping
rem date:5.8.2023
rem desc:backup all database datafile in archive
–connect database
connect internal/password;
–archive
alter system archive log current;
–start
alter tablespace system begin backup;
!xcopy d:/Oracle/oradata/test/system01.dbf d:/databak/H/R;
alter tablespace system end backup;
alter tablespace rbs begin backup;
!xcopy d:/Oracle/oradata/test/rbs01.dbf d:/databak/H/R;
alter tablespace rbs end backup;
alter tablespace users begin backup;
!xcopy d:/Oracle/oradata/test/users01.dbf d:/databak/H/R;
alter tablespace users end backup;
alter tablespace tools begin backup;
!xcopy d:/Oracle/oradata/test/tools01.dbf d:/databak/H/R;
alter tablespace tools end backup;
alter tablespace indx begin backup;
!xcopy d:/Oracle/oradata/test/indx01.dbf d:/databak/H/R;
alter tablespace indx end backup;
–end
–bak control file
–binary
alter database backup controlfile to ‘d:/databak/controlbinbak.000’;
–ascii
alter database backup controlfile to trace;
alter system archive log current;
说明:
1、热备份必须在数据库归档方式下才可以运行;
2、以上脚本可以在数据库运行状态下备份数据库所有的数据文件(除了临时数据文件),没有必要备份联机日志;
3、归档日志至少需要一次完整备份之后的所有日志;
4、如果以上命令没有成功依次执行,那么备份也是无效的,如连接数据库不成功,那么备份则无效。
RMAN备份只讲叙有恢复目录的情况,如果没有恢复目录,情形大致相似。以下是RMAN的热备份全备份的脚本:
# script:bakup.rcv
# creater:chenjiping
# date:5.8.2023
# desc:backup all database datafile in archive with rman
# connect database
connect rcvcat rman/rman@back;
connect target internal/virpure;
# start backup database
run{
allocate channel c1 type disk;
backup full tag ‘dbfull’ format ‘d:/backup/full%u_%s_%p’ database
include current controlfile;
sql ‘alter system archive log current’;
release channel c1;
}
# end
说明:
1、 数据库必须运行在归档模式下;
2、 RMAN将自动备份数据文件,运行可靠;
3、 归档日志另外备份处理,但至少需要保存一次备份来的日志;
4、 没有必要用RMAN做冷备份,效果不好。
以上举例说明了数据库的恢复案例的测试环境与部分备份测试脚本,其它的备份脚本可以根据以上脚本演变而来或在案例中加以说明。
数据库的自动实例将不加以说明,这里只举例说明媒体错误或人为错误造成的恢复可能。
以上包括以下案例都是在WINDOWS+Oracle816上测试验证的,在不同的操作系统与不同的数据库版本中略有差别。
关于oracle数据库表恢复的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。