--删除空的表
空间,但是不包含
物理文件\x0d\x0adroptablespacetablespace_name\x0d\x0a--删除非空表空间,但是不包含物理
文件\x0d\x0adroptablespacetablespace_nameincludingcontents\x0d\x0a--删除空表空间,包含物理文件\x0d\x0adroptablespacetablespace_nameincludingdatafiles\x0d\x0a--删除非空表空间,包含物理文件\x0d\x0adroptablespacetablespace_nameincludingcontentsanddatafiles\x0d\x0a--如果其他表空间中的表有外键等约束关联到了本表空间中的表的字段,就要加上CASCADECONSTRAINTS\x0d\x0adroptablespacetablespace_nameincludingcontentsanddatafilesCASCADECONSTRAINTS说明:必须在脱机状态下才能删除表空间。\x0d\x0a第一步:用sys权限登录oracle\x0d\x0aSQL>connect sys/wellhope as sysdba\x0d\x0a第二步:找到表空间的存储位置后,执行脱机命令。datafile 后面的就是绝对路径。\x0d\x0aSQL>alter database datafile '/home/oracle/ora/products/9.2.0/oradata/ora9i/tablespace_ecms.dbfoffline drop\x0d\x0a第三步:打开数据库连接\x0d\x0aSQL>alter database open\x0d\x0a第四步:删除表空间“ tablespace_ecms”。\x0d\x0aSQL>drop tablespace tablespace_ecms INCLUDing contents
oracle删除表,释放表空间,需要通过truncate table xx,然后drop table xxx 来释放,或者直接通过 drop table xxx purge;
示例如下:
1、创建测试表,
create table test_space(id number, name varchar2(20))
2、插入样例数据,
insert into test_space
select level, 'test_space_'||level
from dual
connect by level<100000
3、查看该表存储,占用3145728B大小,
select * from user_segments t where segment_name = upper('test_space')
4、truncate清空表数据,truncate table test_space,然后再次查询表存储,存储变为65536B,已释放;
truncate table test_space
select * from user_segments t
where segment_name = upper('test_space')
5、把表再次删除后,存储已释放;
drop table test_space
select bytes from user_segments t
where segment_name = upper('test_space')
评论列表(0条)