当前位置:首页 » 数据仓库 » oracle数据库覆盖还原
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

oracle数据库覆盖还原

发布时间: 2023-03-02 05:12:23

Ⅰ oracle数据库如何还原

第一:用安装数据库时的管理员用户登录:创建一个新的用户,如:x0dx0a//创建用户123密码456x0dx0acreate user 123 identified by 456;x0dx0a第二:授权,赋予dba的权限x0dx0agrant dba to 123;x0dx0a第三:导入数据库x0dx0aimp 123/456@orcl file=E:\*.DMP fromuser=expuser touser=123x0dx0a注意:如上导入需要直接在cmd界面执行;expuser是导出用户名,可以随便写,但会有警告;orcl是你创建的数据库事例,在安装oracl的时候,默认会新建一个orclx0dx0a最后:希望我描述清楚了,能帮到你。

Ⅱ oracle用imp还原数据库时能覆盖原来数据库吗

应该是不可以,imp执行的操作,就是建表、建视图等对象,导入数据(执行插入操作);
没有在插入前,执行清空(delete等)的操作。

Ⅲ Oracle数据被删除后,如何恢复

删除表后,可以采用如下操作:
在 user_recyclebin中找到最近操作过的表名称,然后用闪回(只能用于10G及以上版本)。
FLASH BACK TABLE TABLE_NAME TO BEFORE DROP;
如果是删了或修改里面的数据,可以先建立一个快表将删除修改之前状态的数据找回到这个表中:
CREATE TABLE QUICK_TABLE AS
SELECT * FROM TABLE_NAME AS OF TIMESTAMP SYSDATE-1/24 (一小时前的),减去的时间可以自己定 如:select * from TABLE_NAME AS OF TIMESTAMP (SYSTIMESTAMP - INTERVAL '1' MINUTE)

Ⅳ linux系统 还原oracle数据库步骤跟命令

数据还原:

1.在命令行输入:sqlplus "/as sysdba"

2. 执行以下语句登录xx数据库,用户名:xx,密码:xx(请输入当地实际密码)
conn xx/xx;

3.如果恢复的表中有涉及到触发器的请停止触发器,例:A表

alter table A disable all triggers;

commit;

4. 执行以下语句退出当前用户
quit;
5. 执行以下语句,恢复用户数据。
impdp xx/xx@数据库实例名 directory=bak_dir table_exists_action=truncate mpfile=expdb_xx.dmp logfile=impdb_xx.log

5.在命令行输入:sqlplus "/as sysdba"

6. 执行以下语句登录xx数据库,用户名:xx,密码:xx(请输入当地实际密码)
conn xx/xx;

7. 执行以下语句打开被禁止的触发器

alter table A enable all triggers;

commit;

Ⅳ 重装系统后,怎么恢复oracle数据库

任何软件都有可能在有意或无意的情况下被重新安装,如Oracle重装后数据库怎么恢复呢?情况发生在你是无意的情况下!ORACLE数据库恢复的方法我们经常会用到,下面就为您介绍重装系统后ORACLE数据库恢复的方法,希望对您学习ORACLE数据库恢复方面能有所帮助。x0dx0ax0dx0a我的电脑突然挂了,不得不重装系统,不过我的ORACLE装在了D盘,所有的文件都还在,我相信一定能够恢复,直到搞定工作,我才开始整我的数据库,花了两天时间,终于恢复了,庆祝一下,同时总结一下,希望有遇到同样问题的朋友能够快速搞定此类问题x0dx0ax0dx0a第一种:x0dx0ax0dx0a首先,备份数据库(X:\oracle\oradata)下的数据文件,重新命名即可(否则装数据库的时候会提示sid已存在)。重新安装数据x0dx0a库,当然数据库的名字就是你要恢复的名字。安装完成后,打开控制面板,停止oracle的服务。把(X:\oracle\oradata)下新生成的文件x0dx0a改名,把原先目录下的文件恢复名字。再重新启动oracle服务和监听。用sys/as dba x0dx0a登陆数据库,可能会提示权限不够(ora-01031)修改(X:\oracle\ora92\network\admin x0dx0a)文件夹下的sqlnet.ora文件,添加SQLNET.AUTHENTICATION_SERVICES= x0dx0a(NTS),增加权限。登陆进去后,打开table提示不能打开。打开common页,执行命令alert database x0dx0aopen;这时再刷新table,发现原先的表可以打开了。恢复成功了。再用原先数据库的普通用户进入。发现一切正常。至此,大功告成。x0dx0ax0dx0a第二种:x0dx0ax0dx0a1、首先,将原来的ORACLE文件夹改名,原来的路径是D:/oracle.我暂时改成D:/oracle_old.找来ORACLE(我用x0dx0a的是ORACLE 9I)安装光盘,将ORACLE安装在原来安装的目录下,这样恢复起来更加方便,主要是注册表的内容不用修改。x0dx0ax0dx0a2、安装完了之后,系统中又有一个可以使用的ORACLE了。这个时候要做的就是将原来的文件和数据恢复过来。第一步,先关闭ORACLE的所x0dx0a有已经启动的项目,在"服务"里面逐一关闭。然后,将安装目录改名。我现在用的是D:/oracle.改成D:/oracle_new.再将D:x0dx0a/oracle_old改成D:/oracle. x0dx0a这样理论上说从物理层面恢复了ORACLE了。但是我们发现,现在还不能启动ORACLE的监听程序和服务程序。我们还要从逻辑上解决。x0dx0ax0dx0a3、在dos环境下执行一个删除命令:oradim -delete -sid mm,其中mm为创建oracle时候创建的实例 x0dx0a建议执行这个命令后重新启动机器,重启后就可以建立和原来实例名相同的实例。当然你懒,不重新启动也可以,但是你的实例名就不能和原来的一样了。x0dx0ax0dx0a4、在dos环境下执行命令 oradim -new -sid mm -startmode a -pfile "D:\oracle\admin\mm\pfile\initmm.ora "创建一个新的实例,其中 "mm"为新数据库的名称。x0dx0ax0dx0a5、启动服务,先打开数据库,然后可以用以前的用户名和密码登陆进去。 x0dx0a要补充的是,一般的ORACLE数据库的监听程序都是用电脑的名称来识别地址的,而不是127.0.0.1或者localhost.所以,如果我们安装系x0dx0a统的时候用的是不同的电脑名称(比如我原来用的是wm_mm.重新安装后用的是wenming_mm),那么我们还有一个工作要做,就是修改文件 x0dx0alistener.ora.将里面的相关的东西改过来就可以了。x0dx0ax0dx0a需要耐心、细心,可能在一步里有一个细小的差别就会出些古怪的错误提示,有时需要根据错误提示采取策略,总之原理是,先装一个一模一样的ORACLE,安装目录、数据库名称都一样,这样保证注册表里不用更改;再覆盖物理文件,最后重新实例化,打开数据库就可以进去了。

Ⅵ oracle 数据库如何还原

单击开始,这里输入cmd,打开dos窗口


输入命令


exp bms/BMSPASS@TCDB file=E:DBbackdbback20160112.dmp


这里说明一下


这里的bms是指备份时,登录数据库实例TCDB的用户名;


这里的/是语法符号。


这里的BMSPASS是用户bms登录数据库TCDB时的密码;


@是语法符号。


这里的TCDB是Oracle数据库的实例名。


这里的file=E:DBbackdbback20160112.dmp 是只指备份文件的存放路径。



等待导出完成,如果看到这里的导出成功,说明备份完成了。



打开备份时指定的存储路径,就可以看到备份文件了。



如果在导出命令的最后加上full=y的参数,也就是


exp bms/BMSPASS@TCDB file=E:DBbackdbback20160112.dmp full=y
意思是将用户bms在TCDB数据库实例中的所有文件都备份,也就是完整备份。



数据库还原使用语法


imp bms/BMSPASS@TCDB file=E:DBbackdbback20160112.dmp
这里的E:DBbackdbback20160112.dmp是备份文件的存放路径

Ⅶ 我的oracle数据库里面覆盖了一张表,怎么还原

用oracle的
flashback
,可以还原查询某个时间点这个表中的数据,只要时间不要过去太久就可以,比如
SELECT
*
FROM
tt_tab
AS
of
TIMESTAMP(SYSDATE-1/24)

Ⅷ oracle数据库中的数据不小心被错误修改了某列的值,如何把它还原而且数据库不在本机

哥们你麻烦了
这个事一定要找dba在本地操作, 两个方法
1 使用 flashback 功能。但是你得祈祷你开了flashback 而且undo tablespace足够大,而且你从出错到开始恢复这段时间数据库操作不太多,没有把你的数据覆盖

2 新建一个库,用原来库的备份restore进去,然后recover到你做了错误操作之前。然后把涉及的表export出来,然后drop掉你原来库中错误的表,再导入进去

当然,还有一种可能,如果你没提交的话,roll back...