create table SPACE_TEMP ( TABLESPACE_NAME CHAR(30), CONTIGUOUS_BYTES NUMBER) / declare cursor query is select * from dba_free_space order by tablespace_name, block_id; this_row query%rowtype; previous_row query%rowtype; total number; begin open query; fetch query into this_row; previous_row := this_row; total := previous_row.bytes; loop fetch query into this_row; exit when query%notfound; if this_row.block_id = previous_row.block_id + previous_row.blocks then total := total + this_row.bytes; insert into SPACE_TEMP (tablespace_name) values (previous_row.tablespace_name); else insert into SPACE_TEMP values (previous_row.tablespace_name, total); total := this_row.bytes; end if; previous_row := this_row; end loop; insert into SPACE_TEMP values (previous_row.tablespace_name, total); end; . / set pagesize 60 set newpage 0 set echo off ttitle center 'Contiguous Extents Report' skip 3 break on "TABLESPACE NAME" skip page duplicate spool contig_free_space.lis rem column "CONTIGUOUS BYTES" format 999,999,999,999 column "COUNT" format 999 column "TOTAL BYTES" format 999,999,999,999 column "TODAY" noprint new_value new_today format a1 rem select TABLESPACE_NAME "TABLESPACE NAME", CONTIGUOUS_BYTES "CONTIGUOUS BYTES" from SPACE_TEMP where CONTIGUOUS_BYTES is not null order by TABLESPACE_NAME, CONTIGUOUS_BYTES desc; select tablespace_name, count(*) "# OF EXTENTS", sum(contiguous_bytes) "TOTAL BYTES" from space_temp group by tablespace_name; spool off drop table SPACE_TEMP /example output:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
SQL> @TFSTSFRM
Table
created.
PL/SQL
procedure
successfully completed.
Contiguous Extents Report
TABLESPACE
NAME
CONTIGUOUS BYTES
------------------------------ ----------------
EXAMPLE 32,768,000
Contiguous Extents Report
TABLESPACE
NAME
CONTIGUOUS BYTES
------------------------------ ----------------
SYSAUX 3,211,264
Contiguous Extents Report
TABLESPACE
NAME
CONTIGUOUS BYTES
------------------------------ ----------------
SYSTEM 371,130,368
SYSTEM 393,216
Contiguous Extents Report
TABLESPACE
NAME
CONTIGUOUS BYTES
------------------------------ ----------------
UNDOTBS1 13,500,416
UNDOTBS1 524,288
UNDOTBS1 458,752
UNDOTBS1 458,752
UNDOTBS1 327,680
UNDOTBS1 262,144
UNDOTBS1 196,608
UNDOTBS1 131,072
UNDOTBS1 131,072
UNDOTBS1 131,072
UNDOTBS1 65,536
UNDOTBS1 65,536
UNDOTBS1 65,536
UNDOTBS1 65,536
UNDOTBS1 65,536
UNDOTBS1 65,536
UNDOTBS1 65,536
Contiguous Extents Report
TABLESPACE
NAME
CONTIGUOUS BYTES
------------------------------ ----------------
USERS 10,995,367,936
USERS 1,048,576
USERS 393,216
USERS 262,144
USERS 196,608
26
rows
selected.
Contiguous Extents Report
TABLESPACE_NAME #
OF
EXTENTS TOTAL BYTES
------------------------------ ------------ ----------------
EXAMPLE 1 32,768,000
UNDOTBS1 17 16,580,608
USERS 7 10,997,268,480
SYSAUX 1 3,211,264
SYSTEM 2 371,523,584
Table
dropped.
|
本文转自maclean_007 51CTO博客,原文链接:http://blog.51cto.com/maclean/1276732