回收表空间

上课实验---回收表空间

以DBA身份建一个视图:

create or replace view dba_tablespace_free as
select a.tablespace_name,a.total_space_mb allocated_space_mb,round(b.free_space_mb,2) free_space_mb,(a.max_space-

a.total_space_mb) free_allocate_mb,round(a.max_space,2) max_space_mb,
round((a.total_space_mb-b.free_space_mb)/a.total_space_mb*100,2) pct_usage,round(a.total_space_mb/a.max_space*100,2) 

pct_allocated
from (select tablespace_name,sum(bytes)/1024/1024 total_space_Mb,decode(sum(maxbytes/1024/1024),0,
sum(bytes)/1024/1024,sum(case when AUTOEXTENSIBLE='YES' then maxbytes
                             else bytes end)/1024/1024) max_space
 from dba_data_files  group by tablespace_name)a,(select tablespace_name, sum((bytes)/1024/1024) free_space_Mb
 from dba_free_space group by tablespace_name) b where a.tablespace_name=b.tablespace_name;

1. 创建表空间:

create tablespace cindy datafile '/u01/oracle/cindy.dbf'  size 10M autoextend on next 50M;

2. 创建一个表使用这个表空间:

create table cindy_1 tablespace cindy  as select * from dba_objects ;

3. 查询文件大小:

select BYTES/1024/1024,MAXBYTES/1024/1024 from Dba_Data_Files where tablespace_name ='CINDY';

--可以看到文件大小是10M
4.继续往表里插入数据并提交:

 insert into   cindy_1   select * from dba_objects ;

5.执行第3步的查询,可以看到大小变成60M,因为表空间自动扩展了50M
6.用pl/sql dev查询:

SELECT UPPER(F.TABLESPACE_NAME) "表空间名",
  D.TOT_GROOTTE_MB "表空间大小(M)",
  D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",
  TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),'990.99') || '%' "使用比",
  F.TOTAL_BYTES "当前空闲空间(M)",
    (SELECT free_space_mb+free_allocate_mb FROM dba_tablespace_free a where a.tablespace_name= f.tablespace_name) "总剩余空

间",
  F.MAX_BYTES "最大块(M)"
  FROM (SELECT TABLESPACE_NAME,
  ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
  ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
  FROM SYS.DBA_FREE_SPACE
  GROUP BY TABLESPACE_NAME) F,
  (SELECT DD.TABLESPACE_NAME,
  ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB
  FROM SYS.DBA_DATA_FILES DD
  GROUP BY DD.TABLESPACE_NAME) D
  WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
and f.tablespace_name='CINDY'
  ORDER BY 3 desc;

这里可以看到表空间只使用了31.67%,再往表里插入数据并提交

insert into cindy_1   select * from cindy_1 ;

再执行第6步的查询

可以看到表空间使用了58.33%,现在想回收表空间


回收数据文件:

select FILE_ID from dba_data_files where tablespace_name='CINDY';

这里时找到数据文件的id

alter database datafile 7 resize 40M;

然后再次执行第6步的查询,这时再查看数据文件,就变成使用40M

select BYTES/1024/1024,MAXBYTES/1024/1024 from Dba_Data_Files where tablespace_name ='CINDY';

7.在该表空间下,继续建另一张表:

create table cindy_2 tablespace cindy as select * from dba_objects;

执行第6步的查询,可以看到用了44M了

8.删除表1:

truncate table cindy_1;

再执行第6步的查询,可以看到用了10.06M,是否可以回收11M

alter database datafile 7 resize 11M;

此时会报ORA-03297

select  segment_name,block_id,blocks FROM dba_extents where Tablespace_name ='CINDY' order by block_id desc;

CINDY_2占用的空间等于5504-4480+128=1152 ,即表2的最大id-表2的最小id+128

这里有个解释理解是:
 说表1 建好了,里面有数据,后来建了表2,里面也有数据,这个时候,可以查看到表空间的使用大小,然后,把表1truncate掉,再去查看


表空间的使用大小,值是小了
但是我们却回收不了
就比如说,建一栋楼,1楼到4楼建好了,有人住进去了,然后建了5楼,也有人住进去了,这时可以看到整个楼的入住大小情况,然后,1楼


到4楼的人都搬走了,再去看楼的入住情况,值是小了
但是我们却回收不了1楼到4楼,是因为5楼有人住着呢


那么此时想回收,必须先把cindy_2 move掉

alter table cindy_2 move;

然后再去回收

alter database datafile 7 resize 11M;

再去执行第6步的查询,可以看到,此时回收成功

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值