因更换服务器需要将Oracle数据库转移到另外台Oracle中。
说明:
1、测试环境为:windows server2003 和 oracle 10g.
2、2台服务器安装的程序目录一样,数据目录不一样。
特别借签了Afshen兄弟发的实践将oracle冷备份恢复到另外一个数据库实例中操作文章。但是对于新手来说没有详细说明,且我的操作有点点差异。另外我是新手,只知道工作完成,但是不知道是否此操作是否对于数据库使用存在何影响,还需要后期开发使用在知道,希望能给大家提供对比作为操作中的参考。(因时间仓促未俯图)

1)在A数据库服务器操作:
将需要转移的数据库A冷备份,冷备份,我很简单。
开始->运行:sqlplus
sqlplus>conn SourDB sys as sysdba
sqlplus>shutdown immediate \\关闭数据库实例
在提示后ORACLE 例程已经关闭后,将对应A数据库中的e:\Oracle\oradata\SourDB数据库目录全部拷贝出来。
我的数据库目录内含REDO01.LOG 、REDO02.LOG、REDO03.LOG,SYSAUX01.DBF,SYSTEM01.DBF,TEMP01.DBF,UNDOTBS01.DBF,USERS01.DBF,ZJTEST.DBF
CONTROL01.CTL,CONTROL02.CTL,CONTROL03.CTL
疑惑:这3个控制文件后面发现没用上,新数据库重新生成控制文件就行了。因新接触不了解,哪位同学知道的,解疑下。

2)在B数据库(实例DestDB)
我的程序安装在x:\oracle\product\10.1.0\db_1\
数据目录在x:\oracle\database\DestDB(无子目录)
a、备份数据库B的控制文件
开始->运行:sqlplus
sqlplus>conn DetDB sys as sysdba
sqlplus>alter database backup controlfile to trace
sqlplus>show parameter spfile; //显示spfile路径
sqlplus>create pfile from spfile; //备份数据库B的控制文件,生成的文件在x:\oracle\product\10.1.0\db_1\database\下的INITDestDB.ORA,备份吧。

b、sqlplus>shutdown immediate \\关闭数据库实例

删除数据目录在x:\oracle\database\DestDB的目录下的数据文件、控制文件和日志文件,反正我是目录下的都删除了。将数据库A备份的sourDB的*.log、*.DBF复制进去。

删除数据库B中的,x:\oracle\product\10.1.0\db_1\database\SPFILEDestDB.ORA控制文件

修改INITDestDB.ORA文件,删除*.control_files对应的字串

c、启动数据库B到nomount状态
开始->运行:sqlplus /nolog
sql>conn DestDB as sysdba
sql>startup nomount
ORACLE 例程已经启动。
Total System Global Area 171966464 bytes
Fixed Size 787988 bytes
Variable Size 144964076 bytes
Database Buffers 25165824 bytes
Redo Buffers 1048576 bytes

\\使用下面的语句生成数据库B的新的控制文件,将DestDB改掉目录的数据库名就行了。
sql>CREATE CONTROLFILE SET DATABASE "DestDB" RESETLOGS ARCHIVELOG
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 454
LOGFILE
GROUP 1 'x:\oracle\database\DestDB\REDO01.LOG' SIZE 10M,
GROUP 2 'x:\oracle\database\DestDB\REDO02.LOG' SIZE 10M,
GROUP 3 'x:\oracle\database\DestDB\REDO03.LOG' SIZE 10M
DATAFILE
'x:\oracle\database\DestDB\SYSTEM01.DBF',
'x:\oracle\database\DestDB\UNDOTBS01.DBF',
'x:\oracle\database\DestDB\SYSAUX01.DBF',
'x:\oracle\database\DestDB\USERS01.DBF',
'x:\oracle\database\DestDB\ZJTEST.DBF'
CHARACTER SET ZHS16GBK;

关闭数据库
sql>shutdown immediate

d、添加(参考备份的initsourDB.ORA)
*.control_files='x:\oracle\database\DestDB\control01.ctl','x:\oracle\database\DestDB\control02.ctl','x:\oracle\database\DestDB\control03.ctl'
新的控制文件,生成到目录x:\oracle\database\DestDB,修改x:\oracle\product\10.1.0\db_1\database\下的initsourDB.ORA,我看到我的目录内生成了3个控制文件,所以加了3个。

e、指定pfile参数启动,并生成spfile,完成恢复工作。
sql>startup pfile="x:\oracle\product\10.1.0\db_1\database\initsourDB.ORA";
ORACLE 例程已经启动。
Total System Global Area 171966464 bytes
Fixed Size 787988 bytes
Variable Size 144964076 bytes
Database Buffers 25165824 bytes
Redo Buffers 1048576 bytes
数据库装载完毕。
ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项

SQL> alter database open resetlogs;
数据库已更改。

SQL> create spfile from pfile;
文件已创建。

SQL> select count(*) from dba_users;
COUNT(*)
----------
30
SQL> select count(*) from dba_users where username='test';
COUNT(*)
----------

文章出处:飞诺网(www.diybl.com):http://www.diybl.com/course/7_databases/oracle/oraclejs/20110814/558381.html

1、首先安装一个全新的Oracle,包括服务名、SID,安装目录应最好与原来的ORACLE目录一致。

2、删除安装目录下所有的datafile、logfile.(oradata目录下的文件)

3、Copy原来的数据文件到oradata目录下,包括系统数据文件等。

4、alter database backup controlfile to trace; 备份当前数据库控制文件,控制文件一般备份到D:\oracle\PRoduct\10.2.0\admin\bstest\udump下,请注意最新一个就是了。

删除原控制文件,重新创建一个控制文件,请注意修改各个路径的位置,如下:

CREATE CONTROLFILE SET DATABASE "TEST" RESETLOGS NOARCHIVELOG

MAXLOGFILES 16

MAXLOGMEMBERS 3

MAXDATAFILES 100

MAXINSTANCES 8

MAXLOGHISTORY 292

LOGFILE

GROUP 1 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\REDO01.LOG' SIZE 50M,

GROUP 2 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\REDO02.LOG' SIZE 50M,

GROUP 3 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\REDO03.LOG' SIZE 50M

-- STANDBY LOGFILE

DATAFILE

'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\SYSTEM01.DBF',

'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\UNDOTBS01.DBF',

'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\SYSAUX01.DBF',

'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\USERS01.DBF',

'D:\ORACLE\PRODUCT\10.2.0\ORADATA\BSTEST\TEST.DAT'

CHARACTER SET ZHS16GBK

;

注意修改数据文件的路径,如果是原数据文件,加上你原来所有的数据文件路径,如红色则是我原来的数据文件。

11、重启,启动到startup mount;然后 

执行recover database;成功,

再执行alter database open;打开成功了。

12、现在已基本成功了,但是经过这样处理,为了安全起见,

最好用EXP先将数据全部导出,然后再重新安装ORACLE,然后再用IMP重新导入。

而当我导出时却出现错误:提示临时表空间为空。

用select name from v$tempfile;查看,确实为空,则:

如temp01.dbf已存在,则如下:

alter tablespace temp add tempfile 'D:\oracle\product\10.2.0\oradata\bstest\temp01.dbf'

否则:

alter tablespace temp add tempfile 'D:\oracle\product\10.2.0\oradata\bstest\temp01.dbf' size 10M;

再用EXP导出,成功!

还是打不开。出现以下错误:
 alter database open RESETLOGS
*
ERROR 位于第 1 行:
ORA-01092: ORACLE 例程终止。强行断开连接

10、 将UNDO日志改为手动模式:

alter system set undo_management='manual' scope=spfile;

5、startup nomount;启动到nomount状态,然后执行以上控制文件重建语句。

6、执行recover database using backup controlfile until cancel;

输入cancel回车,后出现错误。

7、alter database open resetlogs;执行后出现以下错误。

ORA-01194: 文件1需要更多的恢复来保持一致性
ORA-01110: 数据文件 1: 'D:\ORACLE\ORADATA\ZQKH\SYSTEM01.DBF'

8、#系统文件出错,看到“一致性”自然想到 _allow_resetlogs_corruption的隐含命令
alter system set "_allow_resetlogs_corruption"=true scope=spfile;
9、alter database open RESETLOGS;

转载于:https://www.cnblogs.com/gotoschool/p/5849133.html

将oracle冷备份恢复到另外一个数据库实例中相关推荐

  1. oracle冷备份/恢复

    1.备份 停止所有的oracle服务,复制Oracle目录下的oradata文件夹下的数据库名整个目录复制备份. 这样冷备份就完成了,当然也可以像网上所说的: 示例一.windows环境下的冷备份与恢 ...

  2. oracle异机复制,oracle冷备份恢复和oracle异机恢复使用方法

    一.冷备份1. 冷备份发生在数据库已经正常关闭的情况下,在进行冷备份之前通常要知道需要进行备份文件的名称以及路径 SQL>select name from v$datefile; SQL> ...

  3. Oracle 恢复dmp文件到数据库表中(超大DMP) 【数据系列 3】

    简述 本来我电脑上的docker安装的是oracle 11 结果 oracle 11 xe 支持的 tablespace 最大是11G,但是我的dmp文件是22个G的超大dmp文件.所以很明显是不行的 ...

  4. Oracle 恢复dmp文件到数据库表中 【数据系列 1】

    Mac 恢复dmp文件数据到数据库表 软件环境:Mac电脑上安装的docker中安装的并且运行的镜像,参考自该博客docker安装oracle 我所运行安装的oracle版本为: Oracle Dat ...

  5. oracle如何链接到另外一个数据库DB_LINK

    命令创建从一个库连接的另外一个库: create database link DB_XXX  --创建连接的名字 connect to db_xxx --数据库名 identified by DB-X ...

  6. 远程登录另一个mysql 数据库_Ubuntu中开启MySQL远程访问功能,并将另一个数据库服务器中的数据迁移到新的服务器中...

    技术交流群:233513714 一.开启MyS远程访问功能 1.进入服务器输入netstat -an | grep 3306确认3306是否对外开放,MySQL默认状态下是不对外开放访问功能的.输入以 ...

  7. Ubuntu中开启MySQL远程访问功能,并将另一个数据库服务器中的数据迁移到新的服务器中...

    技术交流群:233513714 一.开启MyS远程访问功能 1.进入服务器输入netstat -an | grep 3306确认3306是否对外开放,MySQL默认状态下是不对外开放访问功能的.输入以 ...

  8. SQL语句将表中数据导入到另一个数据库表中

    insert into database1.dbo.table1(字段1,字段2,...) select 字段1,字段2,... from database2.dbo.table2 转载于:https ...

  9. Oracle数据库实例的创建、删除、修改

    以SUSE10SP2.Oracle10gR2为例. 本文中的数据库实例这一称谓应该换做数据库更为准确,数据库可以理解为是一个物理的静态概念,主要包括一些物理存在的数据库文件,而数据库实例则是一个动态概 ...

最新文章

  1. python用途与前景-Python的发展前景及干货!!
  2. 为什么我们做分布式要用 Redis ?
  3. 【prometheus】alertmanager 配置文件示例
  4. Java 中 Varargs 机制详解
  5. 3.14-19 wc、iconv、dos2unix、diff、vimdiff、rev
  6. linux应用之----多线程
  7. java 连接 sql2005,java与sql server2005 连接有关问题
  8. oauth 使用令牌_使用OAuth2令牌的安全REST服务
  9. PHP Warning: date() [function.date]解决方案
  10. Oracle之自治事务
  11. 获取脚本路径_如何快速有效的写ftp脚本
  12. 推荐几本对于学习WebGL有帮助的书籍
  13. 员工收“老板”QQ消息转账98万 警方挽回被骗资金
  14. 2021新书—《Python机器学习算法与实战》
  15. global shutter和rolling shutter,全局快门与卷帘式快门
  16. 数据挖掘 | 航空公司客户价值分析
  17. dorado java_dorado事件
  18. 笔记 C++11 std::minmax_element() 的使用(寻找最小值和最大值)
  19. 运动耳机品牌推荐,热门六款运动耳机推荐
  20. 2019年终总结---在前端的成长

热门文章

  1. JBPM executionService.deleteProcessInstanceCascade(id)报错
  2. 精通机器学习的5本免费电子书(5 free e-books for machine learning mastery)
  3. MaxCompute Tunnel SDK数据上传利器——BufferedWriter使用指南
  4. 前端那些事之layui篇---实现栅格功能
  5. 适用于System Center 2016所需前期准备工作
  6. 解决Android Device Chooser 找不到设备问题
  7. 深入浅出 JavaScript 数组 v0.5
  8. HDOJ 1166 敌兵布阵
  9. MySQL内部执行流程
  10. 阿里云Elasticsearch 智能化运维实践