表空间及物理文件 删除

背景:

同事不小心创建了一个ts_xx_temp物理文件,导致其他同事经常问我这个是否可以作为临时表空间,为了不引起歧义,删除表空间及物理文件

过程

在测试环境中

创建一个物理文件且表空间名称为TS_ZYK_T
create tablespace TS_ZYK_T
DATAFILE
'+DATADG/prod/datafile/TS_ZYK_T_1M' SIZE 1m;

select * from dba_data_files;
查询到表空间名称为TS_ZYK_T;

SQL> drop tablespace TS_ZYK_T including contents and datafiles;
Tablespace dropped


数据文件中没有了

登陆到服务器上

[grid@vmac1 ~]$ export ORACLE_SID=+ASM1
[grid@vmac1 ~]$ asmcmd
ASMCMD> ls
DATADG/
SYSTEDG/
ASMCMD> cd DATADG 
ASMCMD> ls
PROD/
arch/
ASMCMD> cd PROD
ASMCMD> ls
ARCHIVELOG/
CONTROLFILE/
DATAFILE/
ONLINELOG/
PARAMETERFILE/
TEMPFILE/
spfilePROD.ora
ASMCMD> cd DATAFILE             
ASMCMD> ls
SYSAUX.260.914060367
SYSTEM.259.914060331
TS_ZYK_DATA.278.914434281
TS_ZYK_DATA_1G
UNDOTBS1.261.914060391
UNDOTBS2.263.914060423
USERS.264.914060433

发现确实没有表空间TS_ZYK_T

具体步骤:

SQL> select * from dba_data_files;
SQL> drop tablespace TS_ZYK_T including contents and datafiles;

asmcmd
ASMCMD> ls
DATADG/
SYSTEDG/
ASMCMD> cd DATADG 
ASMCMD> cd PROD
ASMCMD> cd DATAFILE             
ASMCMD> ls
SYSAUX.260.914060367
SYSTEM.259.914060331
TS_ZYK_DATA.278.914434281
TS_ZYK_DATA_1G
UNDOTBS1.261.914060391
UNDOTBS2.263.914060423
USERS.264.914060433



问题:
oracle 11g 有个新特性:oracle 创建完segment,如果没有数据的话,不使用表空间,如果将表空间删除,而该表后面有数据就会报错,
表空间不存在?



答:

在测试中发现,表会被删除,不会报报空间不存在


以下是测试过程

create tablespace TS_ZYK_TEMP
DATAFILE
'+DATADG/prod/datafile/TS_ZYK_TEP_1M' SIZE 1m;

CREATE TABLE GH_TEMP_TABLESPACE
(A VARCHAR2(100))
tablespace TS_ZYK_TEMP
    pctfree 10
    initrans 1
    maxtrans 255
    storage
    (
      initial 8M
      next 1M
      minextents 1
      maxextents unlimited
    );


SQL> SELECT * FROM USER_SEGMENTS T WHERE T.segment_name='GH_TEMP_TABLESPACE';
SEGMENT_NAME                                                                     PARTITION_NAME                 SEGMENT_TYPE       SEGMENT_SUBTYPE TABLESPACE_NAME                     BYTES     BLOCKS    EXTENTS INITIAL_EXTENT NEXT_EXTENT MIN_EXTENTS MAX_EXTENTS   MAX_SIZE RETENTION MINRETENTION PCT_INCREASE  FREELISTS FREELIST_GROUPS BUFFER_POOL FLASH_CACHE CELL_FLASH_CACHE
-------------------------------------------------------------------------------- ------------------------------ ------------------ --------------- ------------------------------ ---------- ---------- ---------- -------------- ----------- ----------- ----------- ---------- --------- ------------ ------------ ---------- --------------- ----------- ----------- ----------------

SQL> 

在user_segment中并没有出现占用空间情况


重新查询表名发现该表名已经不存在了,那么可以这样认为删除表空间时,创建该表的动作也被消除了


上述问题中表空间不存在报错的可能性就比较小,就是说表的结构也被消除了



上一篇:【网站SEO分析】浅谈网站换域名注意事项


下一篇:阿里云服务器如何选择及使用体验!