a.tablespace_name,a.bytes bytes_used,b.largest,round(((a.bytes - b.bytes)/a.bytes)*
100,
2) percent_used
from (
select tablespace_name,sum(bytes) bytes
from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest
from dba_free_space group by tablespace_name) b
where a.tablespace_name=b.tablespace_name order by ((a.bytes - b.bytes) /
a.bytes) desc
查询所有表空间的总容量、已经使用、剩余、已经使用的百分比!
select a.tablespace_name,a.bytes/
1024/
1024 "Sum MB",(a.bytes-b.bytes)/
1024/
1024 "used MB",b.bytes/
1024/
1024 "free MB",
round(((a.bytes-b.bytes)/a.bytes)*
100,
2)
"percent_used"
from
(select tablespace_name,sum(bytes) bytes
from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest
from dba_free_space group by tablespace_name) b
where a.tablespace_name=
b.tablespace_name
order by ((a.bytes-b.bytes)/
a.bytes) desc
一般来说可以把上面的复杂的查询语句放入一个文件中,需要时再调用,或者创建一个试图,需要时可以查询。
1 写入文件:#vi /home/mzl/
percent_used_tablespace.sql
内容:
select a.tablespace_name,a.bytes/
1024/
1024 "Sum MB",(a.bytes-b.bytes)/
1024/
1024 "used MB",b.bytes/
1024/
1024 "free MB",
round(((a.bytes-b.bytes)/a.bytes)*
100,
2)
"percent_used"
from
(select tablespace_name,sum(bytes) bytes
from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest
from dba_free_space group by tablespace_name) b
where a.tablespace_name=
b.tablespace_name
order by ((a.bytes-b.bytes)/
a.bytes) desc
2 导入:
SQL> @/home/mzl/
percent_used_tablespace.sql
SQL>
l
1 select a.tablespace_name,a.bytes
"Sum",a.bytes-b.bytes
"used",b.bytes
"free",
2 round(((a.bytes-b.bytes)/a.bytes)*
100,
2)
"percent_used"
3 from
4 (
select tablespace_name,sum(bytes) bytes
from dba_data_files group by tablespace_name) a,
5 (
select tablespace_name,sum(bytes) bytes,max(bytes) largest
from dba_free_space group by tablespace_name) b
6 where a.tablespace_name=
b.tablespace_name
7* order by ((a.bytes-b.bytes)/
a.bytes) desc
SQL> /
或者创建视图:
create view percent
as
select a.tablespace_name,a.bytes/
1024/
1024 "Sum MB",(a.bytes-b.bytes)/
1024/
1024 "used MB",b.bytes/
1024/
1024 "free MB",
round(((a.bytes-b.bytes)/a.bytes)*
100,
2)
"percent_used"
from
(select tablespace_name,sum(bytes) bytes
from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest
from dba_free_space group by tablespace_name) b
where a.tablespace_name=
b.tablespace_name
order by ((a.bytes-b.bytes)/
a.bytes) desc;
SQL>
select *
from percent;
查看表空间的数据文件是否是自动扩展:
SQL>
select file_name,tablespace_name,autoextensible
from dba_data_files
FILE_NAME TABLESPACE_NAME AUT
--------------------------------------------- ------------------------------ ---
/u01/app/oracle/oradata/orcl/
risenet.dbf RISENET
/u01/app/oracle/oradata/orcl/
perfstat.dbf PERFSTAT NO
/u01/app/oracle/oradata/orcl/
example01.dbf EXAMPLE YES
/u01/disk1/
users01.dbf USERS YES
/u01/app/oracle/oradata/orcl/
sysaux01.dbf SYSAUX YES
/u01/app/oracle/oradata/orcl/
undotbs01.dbf UNDOTBS1
/u01/disk2/
system01.dbf SYSTEM YES
/u01/app/oracle/oradata/orcl/
undotbs02.dbf UNDOTBS2 NO
/u01/disk1/
pioneer_data.dbf PIONEER_DATA YES
/u01/disk2/
pioneer_indx.dbf PIONEER_INDX NO
/u01/disk3/
pioneer_undo.dbf PIONEER_UNDO NO
FILE_NAME TABLESPACE_NAME AUT
--------------------------------------------- ------------------------------ ---
/u01/app/oracle/oradata/orcl/
paul01.dbf PAUL NO
/u01/disk1/
wenchuan.dbf WENCHUAN NO
13 rows selected.
比如表空间PIONEER_INDX已经用了83.33%,数据文件不能自动扩展,可以修改成自动扩展,以免数据写满数据文件。
SQL> alter database datafile
‘/u01/disk2/pioneer_indx.dbf‘ autoextend on;
Database altered.
SQL>
select file_name,tablespace_name,autoextensible
from dba_data_files
where tablespace_name=
‘PIONEER_INDX‘;
FILE_NAME TABLESPACE_NAME AUT
--------------------------------------------- ------------------------------ ---
/u01/disk2/
pioneer_indx.dbf PIONEER_INDX YES
或者给表空间多加一个自动扩展的数据文件,如果有多个硬盘,可以增加多个数据文件(这样多数据库系统的并发性比较好)
SQL>
alter tablespace pioneer_indx add datafile size 30M;
Tablespace altered.
SQL>
select file_name,tablespace_name,bytes/
1024/
1024 "MB"
from dba_data_files
where tablespace_name=
‘PIONEER_INDX‘;
oracle查询表空间的空间占用情况
标签:max pre 调用 altered 扩展 app oracl creat where