在12c版本之前,是不能夠在線重命名和移動數據文件的。很多情況下,需要移動數據文件或重命名,那麼只能停機操作了。
但是到了12c,這個操作就變的非常簡單了,可以在線操作,並且對應用業務沒有任何影響,大大提高了數據庫的高可用性。其實12c很多新特性都是為了提高數據庫的高可用性而出來的,oracle對數據庫高可用性方面越來越重視。
下面介紹12c的在線重命名和移動數據文件。
【正文】
一在線重命名數據文件
首先,創建一個新的叫做TBS_FILE_TO_MOVE的表空間,該表空間只包含一個數據文件。
[oracle@Server ~]$ sqlplus / as sysdba
SQL*Plus: Release 12.1.0.1.0 Production on Fri Dec 20 03:03:50 2013
Copyright (c) 1982, 2013, Oracle. All rights reserved.
Connected to:
Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
SQL> CREATE SMALLFILE TABLESPACE TBS_FILE_TO_MOVE DATAFILE '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf'
SIZE 100M AUTOEXTEND ON NEXT 100M LOGGING DEFAULT NOCOMPRESS
ONLINE EXTENT MANAGEMENT LOCAL AUTOALLOCATE
SEGMENT SPACE MANAGEMENT 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 database move 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關鍵字在線移動數據文件
使用帶有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 database move 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
三使用REUSE關鍵字重命名一個在線數據文件
在"alter database move datafile..."語句中同時指定了REUSE關鍵字,這是因為在我們上一步的重命名操作中,我們曾經指定了KEEP關鍵字在原目錄位置保留了數據文件file_to_move2.dbf,如果我們此時不指定REUSE關鍵字,我們的操作就會因目標數據件存在而報錯,如果指定了REUSE關鍵字,則將會直接覆蓋同名目標數據文件。
SQL>alter database move 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 the control 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 the Operating 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 the Operating 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 database move 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視圖,確認控制文件中也已成功修改。