oracle坏了怎么恢复 oracle怎么恢复误删的数据

Oracle怎么恢复一千张表中的损坏数据打开oracle数据库报错 “system01.dbf需要更多的恢复来保持一致性,数据库无法打开” 。检测数据库文件发现sysaux01.dbf有坏块 , sysaux01.dbf文件损坏 。通过备份进行恢复 。
oracle 数据库如何还原?单击开始 , 这里输入cmd,打开dos窗口
输入命令
exp bms/BMSPASS@TCDB file=E:\DBback\dbback20160112.dmp
【oracle坏了怎么恢复 oracle怎么恢复误删的数据】这里说明一下
这里的bms是指备份时,登录数据库实例TCDB的用户名;
这里的/是语法符号 。
这里的BMSPASS是用户bms登录数据库TCDB时的密码;
@是语法符号 。
这里的TCDB是Oracle数据库的实例名 。
这里的file=E:\DBback\dbback20160112.dmp 是只指备份文件的存放路径 。
等待导出完成,如果看到这里的导出成功,说明备份完成了 。
打开备份时指定的存储路径,就可以看到备份文件了 。
如果在导出命令的最后加上full=y的参数,也就是
exp bms/BMSPASS@TCDB file=E:\DBback\dbback20160112.dmp full=y
意思是将用户bms在TCDB数据库实例中的所有文件都备份,也就是完整备份 。
数据库还原使用语法
imp bms/BMSPASS@TCDB file=E:\DBback\dbback20160112.dmp
这里的E:\DBback\dbback20160112.dmp是备份文件的存放路径
请添加详细解释
oracle数据库如何还原?第一:用安装数据库时的管理员用户登录:创建一个新的用户,如:\x0d\x0a//创建用户123密码456\x0d\x0acreate user 123 identified by 456;\x0d\x0a第二:授权,赋予dba的权限\x0d\x0agrant dba to 123;\x0d\x0a第三:导入数据库\x0d\x0aimp 123/456@orcl file=E:\*.DMP fromuser=expuser touser=123\x0d\x0a注意:如上导入需要直接在cmd界面执行;expuser是导出用户名,可以随便写,但会有警告;orcl是你创建的数据库事例,在安装oracl的时候,默认会新建一个orcl\x0d\x0a最后:希望我描述清楚了,能帮到你 。
重装系统后,怎么恢复oracle数据库?任何软件都有可能在有意或无意的情况下被重新安装,如Oracle重装后数据库怎么恢复呢?情况发生在你是无意的情况下!ORACLE数据库恢复的方法我们经常会用到 , 下面就为您介绍重装系统后ORACLE数据库恢复的方法 , 希望对您学习ORACLE数据库恢复方面能有所帮助 。\x0d\x0a\x0d\x0a我的电脑突然挂了 , 不得不重装系统,不过我的ORACLE装在了D盘,所有的文件都还在,我相信一定能够恢复 , 直到搞定工作,我才开始整我的数据库,花了两天时间,终于恢复了 , 庆祝一下,同时总结一下,希望有遇到同样问题的朋友能够快速搞定此类问题\x0d\x0a\x0d\x0a第一种:\x0d\x0a\x0d\x0a首先,备份数据库(X:\oracle\oradata)下的数据文件 , 重新命名即可(否则装数据库的时候会提示sid已存在) 。重新安装数据\x0d\x0a库,当然数据库的名字就是你要恢复的名字 。安装完成后,打开控制面板,停止oracle的服务 。把(X:\oracle\oradata)下新生成的文件\x0d\x0a改名,把原先目录下的文件恢复名字 。再重新启动oracle服务和监听 。用sys/as dba \x0d\x0a登陆数据库,可能会提示权限不够(ora-01031)修改(X:\oracle\ora92\network\admin \x0d\x0a)文件夹下的sqlnet.ora文件,添加SQLNET.AUTHENTICATION_SERVICES= \x0d\x0a(NTS),增加权限 。登陆进去后 , 打开table提示不能打开 。打开common页,执行命令alert database \x0d\x0aopen;这时再刷新table,发现原先的表可以打开了 。恢复成功了 。再用原先数据库的普通用户进入 。发现一切正常 。至此,大功告成 。\x0d\x0a\x0d\x0a第二种:\x0d\x0a\x0d\x0a1、首先,将原来的ORACLE文件夹改名 , 原来的路径是D:/oracle.我暂时改成D:/oracle_old.找来ORACLE(我用\x0d\x0a的是ORACLE 9I)安装光盘,将ORACLE安装在原来安装的目录下,这样恢复起来更加方便,主要是注册表的内容不用修改 。\x0d\x0a\x0d\x0a2、安装完了之后,系统中又有一个可以使用的ORACLE了 。这个时候要做的就是将原来的文件和数据恢复过来 。第一步,先关闭ORACLE的所\x0d\x0a有已经启动的项目,在"服务"里面逐一关闭 。然后,将安装目录改名 。我现在用的是D:/oracle.改成D:/oracle_new.再将D:\x0d\x0a/oracle_old改成D:/oracle. \x0d\x0a这样理论上说从物理层面恢复了ORACLE了 。但是我们发现 , 现在还不能启动ORACLE的监听程序和服务程序 。我们还要从逻辑上解决 。\x0d\x0a\x0d\x0a3、在dos环境下执行一个删除命令:oradim -delete -sid mm,其中mm为创建oracle时候创建的实例 \x0d\x0a建议执行这个命令后重新启动机器,重启后就可以建立和原来实例名相同的实例 。当然你懒,不重新启动也可以 , 但是你的实例名就不能和原来的一样了 。\x0d\x0a\x0d\x0a4、在dos环境下执行命令 oradim -new -sid mm -startmode a -pfile "D:\oracle\admin\mm\pfile\initmm.ora "创建一个新的实例,其中 "mm"为新数据库的名称 。\x0d\x0a\x0d\x0a5、启动服务,先打开数据库,然后可以用以前的用户名和密码登陆进去 。\x0d\x0a要补充的是,一般的ORACLE数据库的监听程序都是用电脑的名称来识别地址的,而不是127.0.0.1或者localhost.所以,如果我们安装系\x0d\x0a统的时候用的是不同的电脑名称(比如我原来用的是wm_mm.重新安装后用的是wenming_mm),那么我们还有一个工作要做,就是修改文件 \x0d\x0alistener.ora.将里面的相关的东西改过来就可以了 。\x0d\x0a\x0d\x0a需要耐心、细心,可能在一步里有一个细小的差别就会出些古怪的错误提示,有时需要根据错误提示采取策略 , 总之原理是,先装一个一模一样的ORACLE,安装目录、数据库名称都一样,这样保证注册表里不用更改;再覆盖物理文件,最后重新实例化,打开数据库就可以进去了 。
oracle实例无法启动,如何恢复数据对于这个问题,不是一句 , 两句能说清的 。从你叙述的问题来看,能看出你对oracle的框架非常混乱、模糊 。
建议你系统的看一下oracle体系结构的内容,英文好 , 可以直接看官方文档的concept,不好的话可以找一些基础的书籍看
这里,跟你简单说一下oracle的恢复问题
oracle的恢复包括两种:1、实例恢复;2、介质恢复
1、实例恢复:并不需要dba来接入 , 你只要保证undo、redo完整,oracle能自行完成实例恢复 。
2、介质恢复:就是物理文件损坏一类的恢复,或者物理数据的丢失,需要介质恢复 。对于介质恢复的方法,需要看你当初是如何进行备份的 。
至于日志:分为联机在线日志和归档日志 。联机在线日志不可以随便删除 。但是都不绝对 。
而归档日志也一样,也不能随便删除,但是如果对于恢复数据库有用,那么你就不能删除它
总之,这里三言两语是说不清这个问题的 。你想彻底弄明白这样的问题,必须自己把oracle基础的东西掌握了才可以 。
重装系统后oracle怎么恢复1、一种方法是重装数据库后用IMP来导入原来的数据oracle坏了怎么恢复 , 但使用这种方法的前提是你有以前数据的备份,并且这种方法还有许多不足的地方,如备份过旧,可能会丢失许多数据、导入数据太长等 。
一般情况下我们可以采用重用原来的数据库的方法来恢复 。在讲步骤前先说说这种方法的原理 。
数 据库与实例对应,当数据库服务启动后,我们可以用SQLPLUS "/AS SYSDBA"方法连接到一个空闲的例程,当执行startup启动数据库时,首先会在%ORACLE_HOME%/database下找当前SID对应 的参数文件(PFILE或者SPFILE)和密码文件,然后启动例程oracle坏了怎么恢复;接着根据参数文件记录的信息找到控制文件 , 读取控制文件的信息,这就是mount数 据库了;最终根据控制文件的信息打开数据库 。这个过程相当于对数据库着了一次冷备份的恢复 。
下面的具体步骤oracle坏了怎么恢复:(我们假设原库的所有相关文件都存在)1、安装数据库软件只需安装同版本的数据库软件即可,不需要创建数据库 。最好安装在和原来数据库同样的%ORACLE_HOME%下,省得还要修改参数文件路径等 。(直接覆盖原来的oracle即可)再次强调,只安装软件,不创建数据库,否则将数据库软件安装在同样的目录下旧的部分数据文件会被覆盖,这样数据库也不能被恢复了 。
2、新建一个实例在cmd窗口执行oradim -new -sid xinhai注意,这个SID名称最好与你以前的SID一样 , 否则在启动的数据需要指明pfile,并且需要重建密码文件,比较麻烦 。(当然,如果你就不想用原来的SID也可以,把参数文件、密码文件的名称都改成与新SID对应的名称) 。
3、启动数据库做完以上两步,就可以启动数据库了 。用net start 检查oracle服务是否已经启动,如果oracle服务没有启动,则在cmd下运行如下命令:net start oracleservicexinhai然后设定必要的环境变量 , 在cmd窗口运行set ORACLE_SID=xinhai
接着连接数据库sqlplus "/as sysdba"startup
如果正常的话,数据库应该就能起来了
4、启动监听lsnrctl start
5、后续工作经过以上几步后 , 基本上就可以使用oracle了,但是使用起来有点不方便 , 如每次在cmd中启动数据库都需要先SET ORACLE_SID、在本机连接数据库也都需要加上@TNSNAME等 。我们可以修改注册表,添加ORACLE_SID的信息,避免这些麻烦 。
在注册表的HKEY_LOCAL_MACHINESOFTWAREORACLE下新建字符串值,名称为ORACLE_SID,值为xinhai 。也可以将以下内容保持成一个后缀名为reg的文件(文件名随便起),然后双击,即可将信息导入到注册表中 。
Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINESOFTWAREORACLE]"ORACLE_SID"="xinhai"
注意,以上步骤都是在%ORACLE_HOME%、%ORACLE_SID%都与原库一样的情况下讨论的,虽然%ORACLE_HOME%和%ORACLE_SID%可以与原库不一样,但为了减少麻烦和出错的几率,建议不要改变则两个值 。
6、如果系统启动时 还不能启动oracle就增加以下
编辑一个oracle_startup.bat文档 内容为:
set sid=xinhailsnrctl starte:/oracle_startuplog.logsqlplus /nolog @e:oracle_startupsql.txte:/ oracle_startuplog.log
在e盘下增加文档oracle_startuplog.log,内容为:
connect / as sysdba;startup nomount;alter database mount;alter database open;quit
然后把oracle_startup.bat放到系统启动项里面 , 这样每次启动系统时oracle就自动启动了 。
关于oracle坏了怎么恢复和oracle怎么恢复误删的数据的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

    推荐阅读