ORACLE数据库迁移有多种,今天先从物理迁移实验做起。
物理迁移比较简单,但是要求两个库的版本必须一样,且必须事先记录要迁移的库的SID、归档模式、数据文件、日志文件、控制文件、参数文件和密码文件。
迁移过程大致分为以下四步:
1、用迁移的参数文件启库到nomount状态。
数据库默认情况下是用$ORACLE_HOME/dbs/spfile<SID>.ora文件来启动的,如果要用pfile启动的话
就制定pfile文件就可以启动,nomount状态也就是加载参数文件的过程,如果可以成功启动,那么就说明参数文件没有问题
2、启到mount状态,mount状态是加载控制文件的过程。
3、如果可以启到mount状态了,那么就可以进行开库操作了。
4、开库成功之后,就说明迁移成功,可以看看数据丢失没,然后启动监听和配置文件等。
下面进行试验:
说明:如果两个库的目录建的一模一样的话,迁移相对简单,这里演示目录不一样的情况。
查看原库的SID 、数据文件、控制文件、密码文件、参数文件、重做日志文件。
这里就不贴过程了
下面开始正式的步骤:
1、用pfile起到nomount状态
SQL> startup nomount pfile='/u01/app/oracle/product/10.2.0/db_1/dbs/initorcl.ora' ORACLE instance started. Total System Global Area 432013312 bytes Fixed Size 2021344 bytes Variable Size 121636896 bytes Database Buffers 306184192 bytes Redo Buffers 2170880 bytes |
成功之后赶紧用pfile生成spfile文件,方便后面对参数的修改
2、起到mount状态
SQL> alter database mount;
Database altered.
加载控制文件
如果出现错误,就说明控制文件所在的路径和参数文件中的路径不一致,就要修改初始化参数文件中控制文件的参数,然后重新加载
3、起到open状态
SQL> alter database open;
Database altered.
这里出现错误的话,就是数据文件或其他文件找不到
通过
alter database rename file 'home/oracle/1.dbf' /home/oracle/oradata/1.dbf';
来解决。
4 迁移成功,开启监听
ID
----------
1
说明成功了