查看表空间使用率及shrink 表空间
首先,可以通过下面的sql statement来查看表空间的使用情况。注意,该语句是在10g下测试过。
SELECT
FREE.TABLESPACE_NAME, FREE.FREE_SPACE/TOTAL.TOTAL_SPACE
FROM (select TABLESPACE_NAME,sum(bytes)/1024/1024 AS FREE_SPACE from dba_free_space group by TABLESPACE_NAME) FREE,
(select TABLESPACE_NAME,sum(BYTES)/1024/1024 AS TOTAL_SPACE from dba_data_files group by TABLESPACE_NAME) TOTAL
WHERE
FREE.TABLESPACE_NAME=TOTAL.TABLESPACE_NAME;
在知道了表空间的使用情况后,我们可能希望对一些表空间做清理,使其datafile的尺寸变小。这时我们的做法是清理掉一些比较大的表,然后用resize命令来减小datafile的大小。
比如
truncate table scott.big;
alter database datafile '/opt/oradata/orcl/user.dbf' resize 10M;
但是有时你会遇到下面的这种情况。
ERROR at line 1:
ORA-03297: file contains used data beyond requested RESIZE value
这个错误看起来像是说你的datafile中没有足够的空间释放,但其实未必。下面通过实验来了解这个错误。
请耐心看完实验过程。
首先创建表空间和用户
SQL> CREATE TABLESPACE reclaim_ts DATAFILE '/opt/oratop/oradata/c21upg10/reclaim_ts01.dbf' SIZE 1M AUTOEXTEND ON NEXT 1M; Tablespace created. SQL> CREATE USER reclaim_user IDENTIFIED BY reclaim_user DEFAULT TABLESPACE reclaim_ts QUOTA UNLIMITED ON reclaim_ts; User created. SQL> GRANT CREATE SESSION, CREATE TABLE TO reclaim_user; Grant succeeded. SQL> GRANT select on dba_objects to reclaim_user; Grant succeeded.
然后创建表t1
SQL> CONN reclaim_user/reclaim_user
Connected.
SQL> create table t1 as select * from dba_objects; Table created.
创建完表后我们用sys登陆查看一下表空间中 extent的情况。
SQL> SELECT segment_type, segment_name , FILE_ID, BLOCK_ID,blocks,BYTES/1024/1024 from dba_extents WHERE owner = 'RECLAIM_USER' order by block_id; SEGMENT_TYPE SEGMENT_NAME FILE_ID BLOCK_ID BLOCKS BYTES/1024/1024
------------------------------------------------------ ---------------------------- ---------- ---------- ---------- ---------------
TABLE T1 54 9 8 .0625
TABLE T1 54 17 8 .0625
TABLE T1 54 25 8 .0625
TABLE T1 54 33 8 .0625
TABLE T1 54 41 8 .0625
TABLE T1 54 49 8 .0625
TABLE T1 54 57 8 .0625
TABLE T1 54 65 8 .0625
TABLE T1 54 73 8 .0625
TABLE T1 54 81 8 .0625
TABLE T1 54 89 8 .0625
TABLE T1 54 97 8 .0625
TABLE T1 54 105 8 .0625
TABLE T1 54 113 8 .0625
TABLE T1 54 121 8 .0625
TABLE T1 54 129 8 .0625
TABLE T1 54 137 128 1
TABLE T1 54 265 128 1
TABLE T1 54 393 128 1
TABLE T1 54 521 128 1
TABLE T1 54 649 128 1
TABLE T1 54 777 128 1
看到从block 9 开始 到 block 777 这一部分连续的block是t1占用的。 之前的8个block应该是datafile自己占用的。
然后我们再创建一个表t2,该表和t1一样 都是从dba_objects创建
SQL> create table t2 as select * from dba_objects; Table created.
OK, 创建完毕后用sys登陆一个session 把datafile 改成 autoextend off。
SQL> alter database datafile '/opt/oratop/oradata/c21upg10/reclaim_ts01.dbf' AUTOEXTEND off; Database altered.
这时候再去查看一下extent的使用情况
SQL> SELECT segment_type, segment_name , FILE_ID, BLOCK_ID,blocks,BYTES/1024/1024 from dba_extents WHERE owner = 'RECLAIM_USER' order by block_id; SEGMENT_TYPE SEGMENT_NAME FILE_ID BLOCK_ID BLOCKS BYTES/1024/1024
------------------------------------------------------ ---------------------------- ---------- ---------- ---------- ---------------
TABLE T1 54 9 8 .0625
TABLE T1 54 17 8 .0625
TABLE T1 54 25 8 .0625
TABLE T1 54 33 8 .0625
TABLE T1 54 41 8 .0625
TABLE T1 54 49 8 .0625
TABLE T1 54 57 8 .0625
TABLE T1 54 65 8 .0625
TABLE T1 54 73 8 .0625
TABLE T1 54 81 8 .0625
TABLE T1 54 89 8 .0625
TABLE T1 54 97 8 .0625
TABLE T1 54 105 8 .0625
TABLE T1 54 113 8 .0625
TABLE T1 54 121 8 .0625
TABLE T1 54 129 8 .0625
TABLE T1 54 137 128 1
TABLE T1 54 265 128 1
TABLE T1 54 393 128 1
TABLE T1 54 521 128 1
TABLE T1 54 649 128 1
TABLE T1 54 777 128 1
TABLE T2 54 905 8 .0625
TABLE T2 54 913 8 .0625
TABLE T2 54 921 8 .0625
TABLE T2 54 929 8 .0625
TABLE T2 54 937 8 .0625
TABLE T2 54 945 8 .0625
TABLE T2 54 953 8 .0625
TABLE T2 54 961 8 .0625
TABLE T2 54 969 8 .0625
TABLE T2 54 977 8 .0625
TABLE T2 54 985 8 .0625
TABLE T2 54 993 8 .0625
TABLE T2 54 1001 8 .0625
TABLE T2 54 1009 8 .0625
TABLE T2 54 1017 8 .0625
TABLE T2 54 1025 8 .0625
TABLE T2 54 1033 128 1
TABLE T2 54 1161 128 1
TABLE T2 54 1289 128 1
TABLE T2 54 1417 128 1
TABLE T2 54 1545 128 1
TABLE T2 54 1673 128 1
紧跟着T1的extent,从block 905开始到1673 是T2占用的。要注意T1在datafile中是排在T2的前面的。两个 表都占用896个block。出去segment就是888个block。
我们看一下现在datafile 的大小
myserver[/export/home/oratop ] du -sh /opt/oratop/oradata/c21upg10/reclaim_ts01.dbf
15M /opt/oratop/oradata/c21upg10/reclaim_ts01.dbf
现在我们把T1 truncate掉,然后再看该数据文件中extent的使用情况
SQL> conn reclaim_user/reclaim_user
Connected.
SQL> truncate table t1; Table truncated.
SQL> SELECT segment_type, segment_name , FILE_ID, BLOCK_ID,blocks,BYTES/1024/1024 from dba_extents WHERE owner = 'RECLAIM_USER' order by block_id; SEGMENT_TYPE SEGMENT_NAME FILE_ID BLOCK_ID BLOCKS BYTES/1024/1024
------------------------------------------------------ ---------------------------- ---------- ---------- ---------- ---------------
TABLE T1 54 9 8 .0625
TABLE T2 54 905 8 .0625
TABLE T2 54 913 8 .0625
TABLE T2 54 921 8 .0625
TABLE T2 54 929 8 .0625
TABLE T2 54 937 8 .0625
TABLE T2 54 945 8 .0625
TABLE T2 54 953 8 .0625
TABLE T2 54 961 8 .0625
TABLE T2 54 969 8 .0625
TABLE T2 54 977 8 .0625
TABLE T2 54 985 8 .0625
TABLE T2 54 993 8 .0625
TABLE T2 54 1001 8 .0625
TABLE T2 54 1009 8 .0625
TABLE T2 54 1017 8 .0625
TABLE T2 54 1025 8 .0625
TABLE T2 54 1033 128 1
TABLE T2 54 1161 128 1
TABLE T2 54 1289 128 1
TABLE T2 54 1417 128 1
TABLE T2 54 1545 128 1
TABLE T2 54 1673 128 1
可以看到T1除了一个 一个segment header不再占用block。 查看dba_free_space也可以看到
SQL> select BLOCK_ID,BLOCKS,BYTES/1024/1024 from dba_free_space where file_id=54; BLOCK_ID BLOCKS BYTES/1024/1024
---------- ---------- ---------------
17 888 6.9375
1801 120 .9375
这个视图的第一个free空间从第17个block开始共888个block。这是t1 truncate释放掉的,共6.9M。
第二个free空间从1801开始用120个block,这是T2到datafile的结尾处的空闲部分。
ok, 既然现在T1释放了6.9M, 结尾处还有接近0.9M的空间,那么我把文件缩小6m 也就是缩小到 15-6=9M 不过分吧?
我们试一下
SQL> alter database datafile '/opt/oratop/oradata/c21upg10/reclaim_ts01.dbf' resize 9m;
alter database datafile '/opt/oratop/oradata/c21upg10/reclaim_ts01.dbf' resize 9m
*
ERROR at line 1:
ORA-03297: file contains used data beyond requested RESIZE value
有错误,显示不行。 resize这个选项只能把datafile中最后一部分free space释放出来。 向T1的这部分free space 因为是在中间,所以没办法释放。但是如果是后面的这0.9M,我们就可以释放掉。
SQL> SELECT 14.1*1024 FROM DUAL; 14.1*1024
----------
14438.4 SQL> alter database datafile '/opt/oratop/oradata/c21upg10/reclaim_ts01.dbf' resize 14439K; Database altered.
那么,这种情况我们怎么处理呢?
两种方法
1. 创建新的表空间
2. move segment到新的表空间
3. drop原来的表空间
4. rename新的表空间使其名字和原来相同
让我们试试。
创建表空间
SQL> create tablespace test DATAFILE '/opt/oratop/oradata/c21upg10/reclaim_ts_01_reorganize.dbf' size 1m autoextend on next 1m; Tablespace created.
给用户赋权让用户可以在新的表空间创建表
SQL> alter user reclaim_user default tablespace test; User altered. SQL> grant unlimited tablespace to reclaim_user; Grant succeeded.
移动原来的表
SQL> alter table reclaim_user.t1 move tablespace test; Table altered. SQL> alter table reclaim_user.t2 move tablespace test; Table altered.
删掉原来的表空间
SQL> DROP TABLESPACE reclaim_ts INCLUDING CONTENTS AND DATAFILES; Tablespace dropped.
重命名表空间并修改datafile
SQL> alter tablespace test rename to reclaim_ts; Tablespace altered. SQL> alter database datafile '/opt/oratop/oradata/c21upg10/reclaim_ts_01_reorganize.dbf' autoextend off; Database altered.
查看数据文件大小
myserver[/export/home/oratop ] du -sh /opt/oratop/oradata/c21upg10/reclaim_ts_01_reorganize.dbf
9.0M /opt/oratop/oradata/c21upg10/reclaim_ts_01_reorganize.dbf
查看表空间使用率及shrink 表空间的更多相关文章
- [转] 使用SQL脚本查看表空间使用率和使用dba_tablespace_usage_metrics视图的差别
传统的SQL脚本查看表空间使用率,使用的关键视DBA_DATA_FILE和DBA_FREE_SPACE. Oracle 11g引入了DBA_TABLESPACE_USAGE_METRICS视图.其实, ...
- db2 查看表空间使用率
1. 统计所有节点表空间使用率 select substr(TABLESPACE_NAME,1,20) as TBSPC_NAME,bigint(TOTAL_PAGES * PAGE_SIZE)/10 ...
- oracle表空间使用率统计查询
今天发现有一张采样表从1月5号开始不记录数据了,所以想查看一下表空间使用率,在网上零零散散找了很多资料,现在记录如下,也不知道哪一个最准确.还有一个就是网上拷贝的sql代码格式太乱了,不好看,找到一个 ...
- SYSAUX表空间使用率高问题处理
SYSAUX表空间做为SYSTEM表空间的辅助表空间,主要存放EM相关的内容以及表统计信息,AWR快照,审计信息等,而假设SYSAUX表空间在默认条件下你假设不做不论什么配置,随着时间的推移.会膨胀的 ...
- Oracle 11gR2 Database UNDO表空间使用率居高不下处理
一.UNDO表空间监控图 Prometheus监控的到UNDO表空间使用率超过90%(90%为所有表空间告警阈值).从图中可以看到,多次增加UNDO表空间的DATAFILE,UNDO表空间达到40GB ...
- (转)oracle表空间使用率统计查询
转自:http://www.cnblogs.com/xwdreamer/p/3511047.html 参考文献 文献1:http://blog.itpub.net/24104518/viewspace ...
- Oracle 11gR2 Database UNDO表空间使用率居高不下-转载
客户的数据库是Oracle Database 11.2.0.3.0 for AIX 6.1 64bit的单机数据库.客户查询DBA_FREE_SPACE发现UNDO表空间的使用率高达98%以上.客户的 ...
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
0.表空间 SQL>select username,default_tablespace from user_users; 查看当前用户的角色 SQL>select * from user ...
- [记录]Zabbix3.4配置监控Oracle12c的存活状态和表空间使用率
Zabbix3.4配置监控Oracle的存活状态和表空间使用率 1.安装zabbix3.4 agent: # rpm -ivh http://repo.zabbix.com/zabbix/3.4/rh ...
随机推荐
- ACM_四数之和
四数之和 Time Limit: 2000/1000ms (Java/Others) Problem Description: 有n个不同的整数,判断能否从中选4次,4个数和刚好为m.数字可重复选取. ...
- 378 Kth Smallest Element in a Sorted Matrix 有序矩阵中第K小的元素
给定一个 n x n 矩阵,其中每行和每列元素均按升序排序,找到矩阵中第k小的元素.请注意,它是排序后的第k小元素,而不是第k个元素.示例:matrix = [ [ 1, 5, 9], [ ...
- 高效程序员的45个习惯·敏捷开发修炼之道(Practices of an Agile Developer)读书笔记
首先,这本书值得再看一遍——这次的阅读,有很多东西都是知其“形”,不知其“神”的,这导致了我对其中某些建议持怀疑态度,接受了的建议也有待商榷. 总之,先记录本书的一些信息: Practices of ...
- TensorFlow OOM when allocating tensor with shape[5000,384707]
在session范围内不要进行eval()或者convert_to_tensor()操作, 否则会造成OOM,或者报出错误:GraphDef cannot be larger than 2GB usi ...
- 主库binlog(master-log)与从库relay-log的关系
主库binlog: # at # :: server id end_log_pos CRC32 COMMIT/*!*/; # at # :: server id end_log_pos CRC32 e ...
- hashtable的用法
C#中哈希表(HashTable)的用法详解 1. 哈希表(HashTable)简述 在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器 ...
- org.apache.jasper.JasperException: javax.el.PropertyNotFoundException: Property [xxx] not readable on type [xxx]
由于javaBean中的属性是custFullName,所以在使用jsp的时候,通过el表达式获取属性的值<td>${m.CustFullName}</td>.但是加载页面的时 ...
- node遍历给定目录下特定文件,内容合并到一个文件
遍历目录用了fs.readdir这个异步方法,得到当前目录下所有的文件和目录的一个数组.然后判断: if文件,并且后缀符合设定的规则(本文例子是符合后缀ts,js)直接用同步方法写入, if目录,继续 ...
- CAD指定区域绘制一个jpg文件
主要用到函数说明: _DMxDrawX::DrawToJpg 把指定区域的内容绘制一个jpg文件中.详细说明如下: 参数 说明 BSTR sJpgFilePath Jpg文件名 DOUBLE dLbx ...
- java_IO_1
public class DirStudy { public static void main(String[] args) { File file = new File("F:/Eclip ...