温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Oracle表空间数据文件移动

发布时间:2020-06-24 03:12:45 来源:网络 阅读:1666 作者:追梦沙哈拉 栏目:关系型数据库

Oracle表空间数据文件移动

系统:windows

oracle:10g


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

一、针对可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表空间也适用


鸣谢:本人参考了多篇文章后总结而得,在此感谢各位网络分享者!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI