Oracle的OMF全称“Oracle managed file”,关于这个概念的参考请自行查阅Oracle官方文档“Using Oracle-Managed Files”(http://download.oracle.com/docs/cd/B19306_01/server.102/b14231/omf.htm#ADMIN003)。关于这项体现Oracle自动化演进的特性的评价褒贬不一。咱不讨论是否推荐在生产系统中引入这项技术,我们一同看一下这个技术带给我们的乐趣。

1.确认系统是否启用OMF特性
Oracle数据库是否启用OMF特性可以通过查看DB_CREATE_FILE_DEST参数来获得。
当DB_CREATE_FILE_DEST参数值为空时表示未启用OMF功能。
sys@ora10g> show parameter db_create_file_dest

NAME                 TYPE                 VALUE
-------------------- -------------------- -------------------
db_create_file_dest  string

2.开启OMF特性
通过修改数据库参数使其生效。方法很多,按照个人喜好进行调整(pfile调整方法,alter system调整参数)。
sys@ora10g> alter system set db_create_file_dest='/oracle/oradata';

System altered.

sys@ora10g> show parameter db_create_file_dest

NAME                  TYPE                 VALUE
--------------------- -------------------- ------------------
db_create_file_dest   string               /oracle/oradata

3.使用OMF特性创建表空间
sys@ora10g> create tablespace tbs_secooler;

Tablespace created.

4.数据文件存放位置
此时Oracle会在/oracle/oradata目录下以数据库实例的大写名字(这里是ORA10G)创建一个目录,表空间对应的数据文件会存放在datafile目录下。
sys@ora10g> !ls -l /oracle/oradata/ORA10G/datafile
total 102512
-rw-r----- 1 oracle oinstall 104865792 Jul 15 05:59 o1_mf_tbs_seco_63x8xzvw_.dbf

5.表空间的默认属性
sys@ora10g> select dbms_metadata.get_ddl('TABLESPACE','TBS_SECOOLER') from dual;

DBMS_METADATA.GET_DDL('TABLESPACE','TBS_SECOOLER')
---------------------------------------------------------------------

  CREATE TABLESPACE "TBS_SECOOLER" DATAFILE
  '/oracle/oradata/ORA10G/datafile/o1_mf_tbs_seco_63x8xzvw_.dbf' SIZE 104857600
  AUTOEXTEND ON NEXT 104857600 MAXSIZE 32767M
  LOGGING ONLINE PERMANENT BLOCKSIZE 8192
  EXTENT MANAGEMENT LOCAL AUTOALLOCATE SEGMENT SPACE MANAGEMENT AUTO

可见,通过OMF方式创建的表空间默认是100M大小,并且是自动扩展的。

6.添加数据文件
可以简单的通过下面的命令为表空间tbs_secooler添加一个数据文件
sys@ora10g> alter tablespace tbs_secooler add datafile;

Tablespace altered.

sys@ora10g> select dbms_metadata.get_ddl('TABLESPACE','TBS_SECOOLER') from dual;

DBMS_METADATA.GET_DDL('TABLESPACE','TBS_SECOOLER')
---------------------------------------------------------------------

  CREATE TABLESPACE "TBS_SECOOLER" DATAFILE
  '/oracle/oradata/ORA10G/datafile/o1_mf_tbs_seco_63x8xzvw_.dbf' SIZE 104857600
  AUTOEXTEND ON NEXT 104857600 MAXSIZE 32767M,
  '/oracle/oradata/ORA10G/datafile/o1_mf_tbs_seco_63x9scb5_.dbf' SIZE 104857600
  AUTOEXTEND ON NEXT 104857600 MAXSIZE 32767M
  LOGGING ONLINE PERMANENT BLOCKSIZE 8192
  EXTENT MANAGEMENT LOCAL AUTOALLOCATE SEGMENT SPACE MANAGEMENT AUTO

sys@ora10g> !ls -l /oracle/oradata/ORA10G/datafile
total 205024
-rw-r----- 1 oracle oinstall 104865792 Jul 15 05:59 o1_mf_tbs_seco_63x8xzvw_.dbf
-rw-r----- 1 oracle oinstall 104865792 Jul 15 06:14 o1_mf_tbs_seco_63x9scb5_.dbf

7.删除表空间数据文件会随之删除
sys@ora10g> drop tablespace tbs_secooler;

Tablespace dropped.

sys@ora10g> !ls -l /oracle/oradata/ORA10G/datafile
total 0

这个特性曾经一度让人们欢呼雀跃。

8.小结
Oracle的OMF特性很少被大规模的应用。原因很多,个人认为OMF虽然带来了操作上的些许便利,但是它隐藏了一些必要细节,同时表空间名字与数据文件名字很难快速建立起对应关系,为后期的管理带来了极大的不便。大家可以在实际环境酌情使用这项技术。

Good luck.

secooler
10.07.14

-- The End --