SELECT d.tablespace_name,
round((1 - nvl(free_space, 0) / space) * 100, 0) "used_rate(%)"
FROM (SELECT tablespace_name,
round(SUM(bytes) / (1024 * 1024), 0) space,
SUM(blocks) blocks
FROM dba_data_files
GROUP BY tablespace_name) d,
(SELECT tablespace_name,
round(SUM(bytes) / (1024 * 1024), 0) free_space
FROM dba_free_space
GROUP BY tablespace_name) f
WHERE d.tablespace_name = f.tablespace_name(+)
UNION ALL --if have tempfile
SELECT D.TABLESPACE_NAME,
ROUND(NVL(USED_SPACE, 0) / SPACE * 100, 2) "USED_RATE(%)"
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 V$TEMP_SPACE_HEADER
GROUP BY TABLESPACE_NAME) F
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME(+)
ORDER BY "used_rate(%)" DESC;
更牛逼的表空間使用率查看
col TABLESPACE_NAME for a20
col SUM_SPACE(M) for a13
col USED_SPACE(M) for a13
col FREE_SPACE(M) for a13
set linesize 120
SELECT D.TABLESPACE_NAME,
SPACE || 'M' "SUM_SPACE(M)",
BLOCKS "SUM_BLOCKS",
SPACE - NVL (FREE_SPACE, 0) || 'M' "USED_SPACE(M)",
ROUND ( (1 - NVL (FREE_SPACE, 0) / SPACE) * 100, 2)
"USED_RATE(%)",
FREE_SPACE || 'M' "FREE_SPACE(M)"
FROM ( SELECT TABLESPACE_NAME,
ROUND (SUM (BYTES) / (1024 * 1024), 2) SPACE,
SUM (BLOCKS) BLOCKS
FROM DBA_DATA_FILES
GROUP BY TABLESPACE_NAME) D,
( SELECT TABLESPACE_NAME,
ROUND (SUM (BYTES) / (1024 * 1024), 2) FREE_SPACE
FROM DBA_FREE_SPACE
GROUP BY TABLESPACE_NAME) F
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME(+)
UNION ALL
SELECT D.TABLESPACE_NAME,
SPACE || 'M' "SUM_SPACE(M)",
BLOCKS SUM_BLOCKS,
USED_SPACE || 'M' "USED_SPACE(M)",
ROUND (NVL (USED_SPACE, 0) / SPACE * 100, 2) "USED_RATE(%)",
NVL (FREE_SPACE, 0) || 'M' "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 V$TEMP_SPACE_HEADER
GROUP BY TABLESPACE_NAME) F
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME(+)
ORDER BY 5 desc;
查看單個數據文件使用率
set line 132
set wrap off
col file_name for a60
select a.file_name,a.bytes/1024/1024 TOTAL,b.sb/1024/1024 FREE,100*b.sb/a.bytes "FREE%"
from dba_data_files a,(select file_id,sum(BYTES) sb from dba_free_space group by file_id) b
where a.file_id=b.file_id order by a.file_name;
SGA內存
Show parameter sga
select tablespace_name, file_id,file_name, round(bytes/(1024*1024),0) total_space from dba_data_files order by tablespace_name;
select * from dba_data_files;可以發現這裏查看沒有temp表空間
select * from dba_tablespaces;這裏卻可以發現temp表空間
select * from dba_temp_files;其實這個語句纔可以看到temp表空間
如何看是否自增長:
SELECT FILE_NAME, TABLESPACE_NAME, AUTOEXTENSIBLE FROM DBA_DATA_FILES
查看所有表
select table_name from dba_all_tables;
巡檢log文件是否有錯
find /usr1/backup/log/bkarch_20130827* | xargs cat|grep ORA
查看一個索引是不是文本索引
select ITYP_NAME from dba_indexes where index_name ='STA_BIZ_FEE_CITY0_ADDRX';
Oracle 文本索引有四種類型:CONTEXT、CTXCAT、CTXRULE 和 CTXXPATH。
查看用戶對應的默認表空間
select username, DEFAULT_TABLESPACE from dba_users;
看心跳線日誌
/oracle/app/crs/log/ha-db1/crsd
看監聽日誌
/oracle/app/db/network/log
11g:$ORACLE_BASE/diag/tnslsnr/<instance_name>/listener/trace目錄下
查看歸檔空間使用率
select * from v$flash_recovery_area_usage;
查看錶空間上有什麼對象
col OWNER for a10
col SEGMENT_NAME for a20
col SEGMENT_TYPE for a10
col PARTITION_NAME for a10
col TABLESPACE_NAME for a15
select t.owner,
t.segment_name,
t.segment_type,
partition_name,
t.tablespace_name,
t.blocks * 8 / 1024 sizem
from dba_segments t
where tablespace_name='XXXXXXXXXXXX'
order by t.blocks desc;
查看用戶數據對象體積
select OWNER,sum(BYTES)/1024/1024 from dba_segments where owner='DLUSER' group by owner;
看數據庫什麼時候啓動的
select STARTUP_TIME from v$instance;
詳細歷史信息只能在alert日誌找咯
怎麼看存儲過程是不是合法?
select OBJECT_NAME,STATUS from dba_objects where object_type='PROCEDURE' and owner='QHBOSS';