东莞市汽车网

标题: Oracle10gR2如何删除误添加的空文件 [打印本页]

作者: 就我不好    时间: 2012-5-15 06:36
标题: Oracle10gR2如何删除误添加的空文件
今天又有学员鸡蛋也可以这样吃问到,当向一个表空间复仇者联盟错误的添加了一个数据对于不对文件,如何来将这个文影子爱人le数据库学习过程中[url=http://house.focus.cn/msgview/226/1/231806512.html]刘德华得女[/urle数据库学习过程中经常碰到的问题,也是让初学者头疼的问题。
    如果是在Oracle10g之前,删除一个表空间中的数据文件后,其文件在数据库数据字典中会仍然存在,除非你删除表空间,否则文件信息不会清除。但是从Oracle10gR2开始,Oracle允许我们彻底删除一个空文件,不留痕迹。
   但是注意:如果你向SYSTEM表空间错误的添加了一个文件,那么就让它在哪里好了,不要动。
   对于普通表空间,则可以参考以下步骤处理:
   数据库版本Oracle10gR2:
SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod
PL/SQL Release 10.2.0.1.0 - Production
CORE    10.2.0.1.0      Production
TNS for Linux: Version 10.2.0.1.0 - Production
NLSRTL Version 10.2.0.1.0 - Production
    向USERS表空间增加一个数据文件:
SQL> alter tablespace users add datafile '/opt/oracle/oradata/eygle/users02.dbf' size 10M;
Tablespace altered.
SQL> select file#,name from v$datafile;
    FILE# NAME
---------- --------------------------------------------------
        1 /opt/oracle/oradata/eygle/system01.dbf
        2 /opt/oracle/oradata/eygle/undotbs01.dbf
        3 /opt/oracle/oradata/eygle/sysaux01.dbf
        4 /opt/oracle/oradata/eygle/users01.dbf
        5 /opt/oracle/oradata/eygle/users02.dbf
5 rows selected.
    确认表空间文件信息:
SQL> select file_name,file_id from dba_data_files where tablespace_name='USERS';
FILE_NAME                                            FILE_ID
-------------------------------------------------- ----------
/opt/oracle/oradata/eygle/users02.dbf                      5
/opt/oracle/oradata/eygle/users01.dbf                      4
    确认表空间未被存储占用:
SQL> select segment_name,file_id,blocks from dba_extents where file_id=5;
no rows selected
    删除表空间中的空数据文件:
SQL> alter tablespace users drop datafile '/opt/oracle/oradata/eygle/users02.dbf';
Tablespace altered.
    检查数据字典,这个空文件的信息已经被彻底清除了:
SQL> select file_name,file_id from dba_data_files where tablespace_name='USERS';
FILE_NAME                                            FILE_ID
-------------------------------------------------- ----------
/opt/oracle/oradata/eygle/users01.dbf                      4




欢迎光临 东莞市汽车网 (http://bbs.qc0769.com/) Powered by Discuz! X3.2