Oracle表空间数据文件移动的方法

本文介绍了如何在Oracle数据库中移动用户表空间和系统表空间的数据文件,包括查看表空间信息,设置表空间脱机,移动文件,修改数据文件路径,以及将表空间恢复在线。涉及的关键操作包括ALTERTABLESPACE和ALTERDATABASE命令。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle表空间数据文件移动的方法

实现把用户表空间中的数据文件从某一个路径移动到另一个路径

一、针对可offline的非系统表空间

本例移动oracle的案例表空间(EXAMPLE表空间),将其从

D:\ORADATA\ORCL\ 移动到 D:\ORACLE\ORADATA\

1.查看要改变的表空间的数据文件信息

SQL> select tablespace_name,file_name,online_status from dba_data_files where tablespace_name=‘EXAMPLE’;

TABLESPACE_NAME FILE_NAME ONLINE_


EXAMPLE D:\ORADATA\ORCL\EXAMPLE01.DBF ONLINE

2.将目标表空间设置为脱机状态

SQL> alter tablespace EXAMPLE offline;

3.再次查看目标表空间的状态,确保其已经是脱机状态

SQL> select tablespace_name,file_name,online_status from dba_data_files where tablespace_name=‘EXAMPLE’;

TABLESPACE_NAME FILE_NAME ONLINE_


EXAMPLE D:\ORACLE\ORADATA\EXAMPLE01.DBF OFFLINE

4.将原来的数据文件移动(或复制)到新的路径

SQL> host move D:\ORADATA\ORCL\EXAMPLE01.DBF D:\ORACLE\ORADATA\

5.修改该表空间的数据文件路径

SQL> alter tablespace EXAMPLE rename datafile ‘D:\ORADATA\ORCL\EXAMPLE01.DBF’
to ‘D:\ORACLE\ORADATA\EXAMPLE01.DBF’;

6.查看该表空间修改后的信息,确保信息无误

SQL> select tablespace_name,file_name,online_status from dba_data_files where tablespace_name=‘EXAMPLE’;

TABLESPACE_NAME FILE_NAME ONLINE_


EXAMPLE D:\ORACLE\ORADATA\EXAMPLE01.DBF OFFLINE

7.修改该表空间为在线状态

SQL> alter tablespace EXAMPLE online;

8.查看该表空间最后结果

SQL> select tablespace_name,file_name,online_status from dba_data_files where tablespace_name=‘EXAMPLE’;
TABLESPACE_NAME FILE_NAME ONLINE_


EXAMPLE D:\ORACLE\ORADATA\EXAMPLE01.DBF ONLINE
备注:本方法对SYSAUX、USERS表空间也适用

二、系统表空间移动

该方法需要数据库处于mount状态

1.关闭运行中的数据库

SQL> shutdown immediate

2.启动数据库到mount状态

SQL> startup mount

3.移动系统表空间(SYSTEM表空间)的数据文件

SQL> host move D:\ORADATA\ORCL\SYSTEM01.DBF D:\ORACLE\ORADATA\

4.修改该表空间的数据文件路径

SQL> alter database rename file ‘D:\ORADATA\ORCL\SYSTEM01.DBF’ to ‘D:\ORACLE\ORA
DATA\SYSTEM01.DBF’;

5.启动数据库,打开实例

SQL> alter database open;

6.查看表空间修改结果

SQL> select tablespace_name,file_name,online_status from dba_data_files where ta blespace_name=‘SYSTEM’;

TABLESPACE_NAME FILE_NAME ONLINE_


SYSTEM D:\ORACLE\ORADATA\SYSTEM01.DBF SYSTEM
备注:本方法对UNDOTBS1、TEMP表空间也适用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值