Oracle如何查看表空间的大小及使用情况
Oracle如何查看表空間的大小及使用情況
注意存在表空間不存在于dba_free_space 中(可能是因?yàn)楸砜臻g過(guò)大已爆掉)
–1、查看表空間的名稱及大小
SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size
FROM dba_tablespaces t, dba_data_files d
WHERE t.tablespace_name = d.tablespace_name
GROUP BY t.tablespace_name;
–2、查看表空間物理文件的名稱及大小
SELECT tablespace_name,
file_id,
file_name,
round(bytes / (1024 * 1024), 0) total_space
FROM dba_data_files
ORDER BY tablespace_name;
–3、查看回滾段名稱及大小
SELECT segment_name,
tablespace_name,
r.status,
(initial_extent / 1024) initialextent,
(next_extent / 1024) nextextent,
max_extents,
v.curext curextent
FROM dba_rollback_segs r, v$rollstat v
WHERE r.segment_id = v.usn(+)
ORDER BY segment_name;
–4、查看控制文件
SELECT NAME FROM v$controlfile;
–5、查看日志文件
SELECT MEMBER FROM v$logfile;
–6、查看表空間的使用情況
SELECT SUM(bytes) / (1024 * 1024) AS free_space, tablespace_name
FROM dba_free_space
GROUP BY tablespace_name;
SELECT a.tablespace_name,
a.bytes total,
b.bytes used,
c.bytes free,
(b.bytes * 100) / a.bytes "% USED ",
(c.bytes * 100) / a.bytes "% FREE "
FROM sys.smtsavaila,sys.sm
tsa?vaila,sys.smts_used b, sys.sm$ts_free c
WHERE a.tablespace_name = b.tablespace_name
AND a.tablespace_name = c.tablespace_name;
–7、查看數(shù)據(jù)庫(kù)庫(kù)對(duì)象
SELECT owner, object_type, status, COUNT(*) count#
FROM all_objects
GROUP BY owner, object_type, status;
–8、查看數(shù)據(jù)庫(kù)的版本
SELECT version
FROM product_component_version
WHERE substr(product, 1, 6) = ‘Oracle’;
–9、查看數(shù)據(jù)庫(kù)的創(chuàng)建日期和歸檔方式
SELECT created, log_mode, log_mode FROM v$database;
–1G=1024MB
–1M=1024KB
–1K=1024Bytes
–1M=11048576Bytes
–1G=1024*11048576Bytes=11313741824Bytes
SELECT a.tablespace_name “表空間名”,
total “表空間大小”,
free “表空間剩余大小”,
(total - free) “表空間使用大小”,
total / (1024 * 1024 * 1024) “表空間大小(G)”,
free / (1024 * 1024 * 1024) “表空間剩余大小(G)”,
(total - free) / (1024 * 1024 * 1024) “表空間使用大小(G)”,
round((total - free) / total, 4) * 100 “使用率 %”
FROM (SELECT tablespace_name, SUM(bytes) free
FROM dba_free_space
GROUP BY tablespace_name) a,
(SELECT tablespace_name, SUM(bytes) total
FROM dba_data_files
GROUP BY tablespace_name) b
WHERE a.tablespace_name = b.tablespace_name
數(shù)據(jù)庫(kù)會(huì)存在temp表空間
查詢temp表空間和使用情況時(shí)需要單獨(dú)的腳本
select d.tablespace_name,
space “sum_space(m)”,
blocks sum_blocks,
used_space “used_space(m)”,
round(nvl(used_space, 0) / space * 100, 2) “used_rate(%)”,
nvl(free_space, 0) “free_space(m)”
from (select tablespace_name,
round(sum(bytes) / (1024 * 1024), 2) space,
sum(blocks) blocks
from dba_temp_files
group by tablespace_name) d,
(select tablespace_name,
round(sum(bytes_used) / (1024 * 1024), 2) used_space,
round(sum(bytes_free) / (1024 * 1024), 2) free_space
from vtempspaceheadergroupbytablespacename)fwhered.tablespacename=f.tablespacename(+)TABLESPACENAMEsumspace(m)SUMBLOCKSusedspace(m)usedrate(但這種情況并不能表示目前臨時(shí)表空間的使用情況,比如某臨時(shí)表空間已經(jīng)使用了100
temps?paceh?eadergroupbytablespacen?ame)fwhered.tablespacen?ame=f.tablespacen?ame(+)TABLESPACEN?AMEsums?pace(m)SUMB?LOCKSuseds?pace(m)usedr?ate(但這種情況并不能表示目前臨時(shí)表空間的使用情況,比如某臨時(shí)表空間已經(jīng)使用了100sort_usgae來(lái)確定:
select sum(blocks*8192)/1024/1024 from v$sort_usage;
臨時(shí)表空間,請(qǐng)查詢DBA_TEMP_FREE_SPACE
SELECT TABLESPACE_NAME, FREE_SPACE/1024/1024 AS “FREE SPACE(M)”
FROM DBA_TEMP_FREE_SPACE
WHERE TABLESPACE_NAME = ‘&tablespace_name’;
臨時(shí)表空間,請(qǐng)查詢DBA_TEMP_FILES
SELECT TABLESPACE_NAME, FILE_ID, FILE_NAME, BYTES/1024/1024 AS “SPACE(M)”
FROM DBA_TEMP_FILES
WHERE TABLESPACE_NAME = ‘&tablespace_name’;
為空間不足的表空間增加數(shù)據(jù)文件
ALTER TABLESPACE &tablespace_name ADD DATAFILE ‘&datafile_name’ SIZE 2G;
注:如果要為臨時(shí)表空間擴(kuò)容,使用下面的語(yǔ)句
ALTER TABLESPACE &tablespace_name ADD TEMPFILE ‘&datafile_name’ SIZE 2G;
也可以修改數(shù)據(jù)文件的大小
---------------------
作者:jing-愛(ài)學(xué)習(xí)
來(lái)源:CSDN
原文:https://blog.csdn.net/qq_24805831/article/details/84782615
版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請(qǐng)附上博文鏈接!
總結(jié)
以上是生活随笔為你收集整理的Oracle如何查看表空间的大小及使用情况的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Oracle建立全文索引详解
- 下一篇: 行内元素中去掉文字的上下间距,使得文字所