oracle学习-数据迁移

如果只是迁移表空间或者数据文件,可以先将表空间或者数据文件offline之后移动位置,并通过

alert database rename 和 alter tablespace rename 将位置变化写入控制文件即可

例 迁移数据文件

ALTER DATABASE DATAFILE ‘所要迁移的数据文件‘ OFFLINE;

拷贝到新位置

ALTER DATABASE RENAME FILE ‘索要迁移的数据文件‘ TO ‘新位置的数据文件‘;

介质恢复

RECOVE DATAFILE ‘新位置的数据文件‘

将相应数据文件ONLINE

ALTER DATABASE DATAFILE ‘新位置的数据文件‘;

例 迁移表空间

将表空间OFFLINE

ALTER TABLESPACE 表空间名 OFFLINE;

拷贝到新位置

ALTER TABLESPACE 表空间名 RENAME DATAFILE ‘旧位置文件‘ TO ‘新位置文件‘;

表空间ONLINE

ALTER TABLESPACE 表空间名 ONLINE;

在MOUNT 状态下迁移整个数据库

需要考虑 数据文件,undo ,Temp,Redo 和控制文件 的迁移

数据文件

1 查看数据文件所在位置

SELECT FILE_NAME FROM DBA_DATA_FILES

UNION ALL

SELECT FILE_NAME FROM DBA_TEMP_FILES;

2 创建新文件夹存放数据文件

mkdir

3 编写脚本进行备份 (其实也可以手动 但是一方面手动的话需要输入大量的命令 二方面可能会因为连接中断而导致进展的不顺利)

vim rcopy.sh

#!/bin/ksh

export LANG=en_US

RMAN_LOG_FILE=${0}.out

ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1

export ORACLE_HOME

RMAN=$ORACLE_HOME/bin/rman

export RMAN

ORACLE_SID=dave

export ORACLE_SID

ORACLE_USER=oracle

export ORACLE_USER

echo "ORACLE_SID:$ORACLE_SID">>$RMAN_LOG_FILE

echo"ORACLE_HOME:$ORACLE_HOME">>$RMAN_LOG_FILE

echo"ORACLE_USER:$ORACLE_USER">>$RMAN_LOG_FILE

echo"==========================">>$RMAN_LOG_FILE

chmod 666 $RMAN_LOG_FILE

$RMAN nocatalog TARGET / msglog$RMAN_LOG_FILE append <<EOF

run

{

allocate channel c1 type disk;

allocate channel c2 type disk;

copy datafile‘/u01/app/oracle/oradata/dave/users01.dbf‘ to ‘/u01/app/oracle/oradata/anqing/users01.dbf‘;

copy datafile‘/u01/app/oracle/oradata/dave/undotbs01.dbf‘ to‘/u01/app/oracle/oradata/anqing/undotbs01.dbf‘;

copy datafile‘/u01/app/oracle/oradata/dave/sysaux01.dbf‘ to‘/u01/app/oracle/oradata/anqing/sysaux01.dbf‘;

copy datafile ‘/u01/app/oracle/oradata/dave/system01.dbf‘to ‘/u01/app/oracle/oradata/anqing/system01.dbf‘;

copy datafile‘/u01/app/oracle/oradata/dave/example01.dbf‘ to‘/u01/app/oracle/oradata/anqing/example01.dbf‘;

copy datafile ‘/u01/app/oracle/oradata/dave/temp01.dbf‘ to ‘/u01/app/oracle/oradata/anqing/temp01.dbf‘;

release channel c2;

release channel c1;

}

EOF

echo >> $RMAN_LOG_FILE

exit

这里记得要赋予该脚本权限 chmod

4 将DB启动到MOUNT状态

shoutdown immediate

startup mount

5 启动脚本

$ nohup sh /u01/rcopy.sh>rcopy.out 2>&1 &

$ jobs

$ jobs

当任务完成后 确认数据文件是否已经拷贝到指定的文件夹当中

ls -lh

6 rname 数据文件

#!/bin/ksh

sqlplus / as sysdba<< EOF

alter database rename file‘/u01/app/oracle/oradata/dave/users01.dbf‘ to ‘/u01/app/oracle/oradata/anqing/users01.dbf‘;

alter database rename file‘/u01/app/oracle/oradata/dave/undotbs01.dbf‘ to‘/u01/app/oracle/oradata/anqing/undotbs01.dbf‘;

alter database rename file‘/u01/app/oracle/oradata/dave/sysaux01.dbf‘ to‘/u01/app/oracle/oradata/anqing/sysaux01.dbf‘;

alter database rename file‘/u01/app/oracle/oradata/dave/system01.dbf‘ to‘/u01/app/oracle/oradata/anqing/system01.dbf‘;

alter database rename file‘/u01/app/oracle/oradata/dave/example01.dbf‘ to‘/u01/app/oracle/oradata/anqing/example01.dbf‘;

exit

EOF

记得给权限chmod

运行 nohup sh rename.sh >rename.out 2>&1 &

7 查看数据库验证是否迁移成功

SELECT FILE_NAME FROM DBA_DATA_FILES

UNION ALL

SELECT FILE_NAME FROM DBA_TEMP_FILES;

这里我们会发现临时表空间可能并未进行迁移 接下来我们进行处理临时表空间数据文件

8 临时表空间数据文件处理

我们在5的时候虽然进行了COPY 临时表空间但是其实并没有COPY成功,RMAN 在备份的时候也不会备份备份locally managed 的tempfiles。原因在于

1. Locally managed tempfiles are always setto NOLOGGING mode. So thus will have no undo.
    2. Extents are managed by bitmap in each datafile to keep track of free or usedstatus of blocks in that datafile.
    3. The data dictionary does not manage the tablespace.
    4. Rollback information is not generated because there is no update on the     datadictionary.
    5. Media recovery does not recognize tempfiles.

所以在拷贝数据文件时,不需要拷贝临时表空间,只需要在拷贝好后给临时表空间添加一个数据文件并把原目录下的临时文件DROP即可

alter tablespace temp add tempfile‘/u01/app/oracle/oradata/anqing/temp01.dbf‘ size 500M autoextend off;

alter tablespace temp drop tempfile‘/u01/app/oracle/oradata/dave/temp01.dbf‘;

再次进行数据文件验证

SELECT FILE_NAME FROM DBA_DATA_FILES

UNION ALL

SELECT FILE_NAME FROM DBA_TEMP_FILES;

检查如果没问题了的话 就可以对原来的数据文件等进行删除处理了

处理REDO LOGFILE

1 查看redo信息

SELECT GROUP#, TYPE, MEMBER FROM $LOGFILE;

SELECT GROUP#, THREAD#. ARCHIVED, STATUS, BYTES/1024/1024 FROM V$LOG;

SELECT b.group#, b.status, a.member,

FROM V$LOGFILE a, V$LOG b

WHERE a.group# = b.group#;

这里我们给予每个group添加一个redo logfile,然后把旧目录下的logfile drop掉即可

这里要助理我们只能drop inactive 和 unused状态下的logfile 其他状态不能drop

alter database add logfile member‘/u01/app/oracle/oradata/anqing/redo01.log‘ to group 1;

alter database add logfile member‘/u01/app/oracle/oradata/anqing/redo02.log‘ to group 2;

alter database add logfile member‘/u01/app/oracle/oradata/anqing/redo03.log‘ to group 3;

验证是否添加成功

select b.group# , b.status ,a.member from v$logfile a , v$log b where a.group# = b.group# order by 1;

2 删除旧的logfile

假设 这里group 1是ACTIVE,我们不能drop,所以我们先drop 2和3,然后switch logfile,在drop group 1。

ALTER DATABASE DROP LOGFILE MEMBER ‘/u01/app/oracle/oradata/dave/redo03.log‘;

ALTER DATABASE DROP LOGFILE MEMBER‘/u01/app/oracle/oradata/dave/redo02.log‘;

ALTER DATABASE DROP LOGFILE MEMBER‘/u01/app/oracle/oradata/dave/redo01.log‘;

最后一条报错 我们需要切换一下日志状态

alter system switch logfile;

再次 drop

ALTER DATABASE DROP LOGFILE MEMBER‘/u01/app/oracle/oradata/dave/redo01.log‘;

验证

select b.group# , b.status , a.memberfrom v$logfile a , v$log b where a.group# = b.group# order by 1;

控制文件迁移

将库shutdown,然后把控制文件copy 到新位置,修改一下pfile参数就可以了

create pfile from spfile;

shutdown immediate

cp 旧控制文件 新控制文件

create spfile frompfile=‘/u01/app/oracle/product/11.2.0/db_1/dbs/initdave.ora‘;

startup

检查

show parameter control_files

大功告成

oracle学习-数据迁移,布布扣,bubuko.com

时间: 2024-10-06 01:16:09

oracle学习-数据迁移的相关文章

MS SQL到Oracle的数据迁移笔记

MS SQL到Oracle的数据迁移笔记 一.任务背景 旧系统使用MS SQL Server数据库,新系统使用Oracle数据库,现在需要将旧系统中的数据迁移到新系统中,旧数据按照约定的规则转换后,能够在新系统中使用或查询.另外,新系统的实施人员并不清楚旧系统的数据结构,且两个新旧两个系统的使用的数据结构有较大的差异.为了叙述方便,将旧系统维护人员简称为A,新系统实施人员简称为B. 二.总体思路 1.  A与B根据各自了解的信息,一起制定中间表: 2.  A从MS SQL Server提取数据,

oracle 数据库数据迁移解决方案

大部分系统由于平台和版本的原因,做的是逻辑迁移,少部分做的是物理迁移,接下来把心得与大家分享一下 去年年底做了不少系统的数据迁移,大部分系统由于平台和版本的原因,做的是逻辑迁移,少部分做的是物理迁移,有一些心得体会,与大家分享. 首先说说迁移流程,在迁移之前,写好方案,特别是实施的方案步骤一定要写清楚,然后进行完整的测试.我们在迁移时,有的系统测试了四五次,通过测试来完善方案和流程. 针对物理迁移,也即通过RMAN备份来进行还原并应用归档的方式(这里不讨论通过dd方式进行的冷迁移),虽然注意的是

oracle跨平台数据迁移 expdp/impdp 字符集问题 导致ORA-02374 ORA-12899 ORA-02372

环境描述: 源数据库环境: 操作系统:Windows SERVER 2008R2 数据库版本:单实例 ORACLE 11.2.0.1 目标端数据库环境: 操作系统:redhat linux 6.5 x86 64bit 数据库版本:ORACLE 11g RAC 11.2.0.4 故障描述: 从源数据库expdp导出数据,然后往目标数据库impdp导入的时候报错: ORA-02374: conversion error loading table "QBJMES"."PROJEC

利用expdp/impdp数据泵对oracle进行数据迁移

按照惯例先报系统环境: 导出环境: 操作系统Release版本:CentOS 6.5 OS内核Kernel版本:2.6.32-431.el6.x86.64 Oracle版本信息: SQL> select * from v$version; BANNER -------------------------------------------------------------------------------- Oracle Database 11g Enterprise Edition Rel

利用Kettle进行SQLServer与Oracle之间的数据迁移实践

Kettle简介 Kettle(网地址为http://kettle.pentaho.org/)是一款国外开源的ETL工具,纯java编写,可以在Windows.Linux.Unix上运行,数据抽取高效稳定. Kettle 中文名称叫水壶,该项目的主程序员MATT 希望把各种数据放到一个壶里,然后以一种指定的格式流出.Kettle中有两种脚本文件,transformation和job,transformation完成针对数据的基础转换,job则完成整个工作流的控制. Windows环境下的安装与配

Oracle数据迁移expdp/impdp

Oracle数据迁移expdp/impdp目的:指导项目侧自行进行简单的数据泵迁移工作. 本文实验环境:Oracle 11.2.0.4,利用数据库自带的scott示例用户进行试验测试. 1.首先需要创建Directory 2.使用expdp导出用户数据 2.1 只导出scott用户的元数据,且不包含统计信息: 2.2 只导出scott用户的数据: 2.3 只导出scott用户下的emp,dept表及数据: 2.4 只导出scott用户下的emp,dept表结构: 2.5 导出scott用户下所有

Oracle学习(八):处理数据

1.知识点:能够对比以下的录屏进行阅读 SQL> --SQL语句 SQL> --1. DML语句(Data Manipulation Language 数据操作语言): insert update delete select SQL> --2. DDL语句(Data Definition Language 数据定义语言): create/alter/drop/truncate table SQL> -- create/drop view,create/drop index(sequ

学习笔记:Oracle 12C 数据非常规恢复工具bbed的使用说明

ORACLE 12C 依然支持 bbed,ORACLE 12C的测试版出来了,对于习惯了使用bbed(ORACLE 手术刀)的人来说,12C是否继续被支持是一个很让人关注的问题,通过本实验测试,12C继续支持bbed,很多艰难的数据库恢复依然可以通过bbed来实现,也从侧面说明,ORACLE 12C在块的结构上还依然和以往版本相似 数据库信息 [[email protected] ~]$ sqlplus / as sysdba SQL*Plus: Release 12.1.0.0.2 Beta

ORACLE 12C 冷备份方式的数据迁移

实验对象:两台linux单机的oracle 12C 数据库(大版本和小版本都一致),数据迁移采取冷备份的方式.目标机器的路径跟源库不一致,需要重建controlfile. 迁移步骤 首先关闭监听,和kill掉连接的应用ps -ef | grep LOCAL=NO | awk '{print ($2)}' | xargs kill -9 创建pfilecreate pfile='/tmp/inittest.ora1012' from spfile;  查看数据文件,日志文件的路径,日志文件路径 S