【摘要】sql
在12c版本以前,是不可以在线重命名和移动数据文件的。不少状况下,须要移动数据文件或重命名,那么只能停机操做了。数据库
可是到了12c,这个操做就变的很是简单了,能够在线操做,而且对应用业务没有任何影响,大大提升了数据库的高可用性。其实12c不少新特性都是为了提升数据库的高可用性而出来的,oracle对数据库高可用性方面愈来愈重视。oracle
下面介绍12c的在线重命名和移动数据文件。app
【正文】ide
首先,建立一个新的叫作TBS_FILE_TO_MOVE的表空间,该表空间只包含一个数据文件。spa
[oracle@Server ~]$sqlplus / as sysdba操作系统
SQL*Plus: Release12.1.0.1.0 Production on Fri Dec 20 03:03:50 2013orm
Copyright (c) 1982,2013, Oracle. All rights reserved.it
Connected to:io
Oracle Database 12cEnterprise Edition Release 12.1.0.1.0 - 64bit Production
With thePartitioning, OLAP, Advanced Analytics and Real Application Testing options
SQL> CREATESMALLFILE TABLESPACE TBS_FILE_TO_MOVE DATAFILE '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf'
SIZE 100M AUTOEXTENDON NEXT 100M LOGGING DEFAULT NOCOMPRESS
ONLINE EXTENT MANAGEMENT LOCAL AUTOALLOCATE
SEGMENT SPACEMANAGEMENT AUTO
Tablespace created.
SQL> select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move.dbf ONLINE
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move.dbf
对新建立的表空间TBS_FILE_TO_MOVE的数据文件"/u01/app/oracle/oradata/NONCDB/file_to_move.dbf"进行了在线重命名:
SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf'
Database altered.
若是在此步骤中尝试使用以前版本中提供的"alter database rename file"命令重命名数据文件的话,则会获得一个ORA-01121的错误,提示指定的数据文件在使用或者回复的同时不能进行重命名。
重命名操做完成以后,咱们发现数据文件在控制文件和操做系统目录中已经显示为新的名字(file_to_move2.dbf),而且其状态仍然为ONLINE。
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf ONLINE
SQL>!ls /u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
使用带有KEEP关键字的"alter database move datafile……"语句,将数据文件file_to_move.dbf重命名为file_to_move1.dbf(模拟数据文件在线移动)。若是在操做中指定了KEEP关键字,则会在原来的位置保留原来的数据文件,并同时会在新的位置建立一个新的数据文件的副本,在这种状况下,当alter语句成功完成后,数据库将仅使用新的数据文件而不会使用原有位置的旧的数据文件。所以,操做完成以后,在控制文件中将仅能看到新的file_to_move1.dbf数据文件,但在操做系统目录中却能同时看到旧的(file_to_move2.dbf)和新的数据文件(file_to_move1.dbf)。
SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf' KEEP
Database altered.
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf ONLINE
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf /u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
在"alter databasemove datafile..."语句中同时指定了REUSE关键字,这是由于在咱们上一步的重命名操做中,咱们曾经指定了KEEP关键字在原目录位置保留了数据文件file_to_move2.dbf,若是咱们此时不指定REUSE关键字,咱们的操做就会因目标数据件存在而报错,若是指定了REUSE关键字,则将会直接覆盖同名目标数据文件。
SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf' REUSE
Database altered.
Data files from thecontrol file:
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf ONLINE
Data files from theOperating System Directory
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
查询到数据文件file_to_move2.dbf所对应的数据文件号为100,接下来,咱们直接使用数据文件file_to_move2.dbf对应的文件号(而不是具体指定其数据文件名称及位置)将其重命名为file_to_move1.dbf。
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf ONLINE
Data files from theOperating System Directory
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
SQL>select file#from v$datafile where name = '/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf'
FILE#
----------
100
SQL>alter databasemove datafile 100 to '/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf'
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf ONLINE
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf
操做完成以后,经过v$datafile视图,确认控制文件中也已成功修改。