Oracle中如何查看表空間使用率
Oracle查看表空間使用率
查看用戶(hù)默認(rèn)表空間
SELECT USERNAME,DEFAULT_TABLESPACE FROM DBA_USERS WHERE USERNAME='DB_USER_NAME';
查看表空間文件路徑、大小、已使用、使用率
SELECT B.FILE_NAME 物理文件名, B.TABLESPACE_NAME 表空間名稱(chēng), B.BYTES/1024/1024 大小M, (B.BYTES-SUM(NVL(A.BYTES,0)))/1024/1024 已使用M, SUBSTR((B.BYTES-SUM(NVL(A.BYTES,0)))/(B.BYTES)*100,1,5) 使用率 FROM DBA_FREE_SPACE A,DBA_DATA_FILES B WHERE A.FILE_ID=B.FILE_ID GROUP BY B.TABLESPACE_NAME,B.FILE_NAME,B.BYTES ORDER BY B.TABLESPACE_NAME;
查看表空間是否開(kāi)啟自動(dòng)擴(kuò)展
SELECT FILE_NAME AS 數(shù)據(jù)文件,TABLESPACE_NAME AS 表空間名稱(chēng),AUTOEXTENSIBLE AS 自動(dòng)擴(kuò)展,STATUS AS 狀態(tài),MAXBYTES AS 可擴(kuò)展最大值,USER_BYTES AS 已使用大小,INCREMENT_BY AS 自動(dòng)擴(kuò)展增量 FROM DBA_DATA_FILES;
創(chuàng)建表空間并開(kāi)啟自動(dòng)擴(kuò)展
CREATE SMALLFILE TABLESPACE TABLE_SPACE_NAME DATAFILE 'E:\APP\ADMINISTRATOR\ORADATA\ORCL\TEST.DBF' SIZE 100M AUTOEXTEND ON NEXT 10M MAXSIZE UNLIMITED NOLOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO DEFAULT NOCOMPRESS;
修改表空間大小
ALTER DATABASE DATAFILE 'E:\APP\ADMINISTRATOR\ORADATA\ORCL\TEST.DBF' RESIZE 200M;
刪除表空間和數(shù)據(jù)文件
DROP TABLESPACE TABLE_SPACE_NAME INCLUDING CONTENTS AND DATAFILES;
查看臨時(shí)表空間信息
SELECT * FROM DBA_TEMP_FILES
Oracle臨時(shí)表空間使用率
今天開(kāi)發(fā)反映說(shuō)臨時(shí)表空間不夠要求添加臨時(shí)表空間,添加完成(添加了30G的臨時(shí)表空間)又報(bào)臨時(shí)表空間的不足,開(kāi)發(fā)又要求是添加,有添加了10G,監(jiān)控臨時(shí)表空間的使用情況,又撐滿(mǎn)了,又添加了30G,最后臨時(shí)表空間又撐滿(mǎn)了,最后批處理還是沒(méi)有執(zhí)行,SQL語(yǔ)句的執(zhí)行是一次性全部執(zhí)行完成,最后的解決辦法是開(kāi)發(fā)使用游標(biāo),一萬(wàn)條數(shù)據(jù)一提交或者定量提交,下午監(jiān)控臨時(shí)表空間的使用情況發(fā)現(xiàn)使用率 74.91%。不禁有些疑問(wèn)到底是那些用戶(hù)在使用臨時(shí)表空間,使用臨時(shí)表空間的大小有多大,
在做一些什么操作,SQL語(yǔ)句是什么。
首先要說(shuō)明一點(diǎn)的是表空間的使用惰性,如果你一下使用幾十個(gè)G的臨時(shí)表空間,如果SQL語(yǔ)句執(zhí)行失敗,臨時(shí)表空間的釋放需要時(shí)間,不會(huì)一下全部釋放,這個(gè)時(shí)候我們檢查臨時(shí)表空間的使用率發(fā)現(xiàn)使用率已經(jīng)是99%,如果你擴(kuò)容臨時(shí)表空間,擴(kuò)容30G,開(kāi)發(fā)又開(kāi)始執(zhí)行sql,你會(huì)發(fā)現(xiàn)臨時(shí)表空間使用率蹭蹭的網(wǎng)上增最后又達(dá)到了99%,開(kāi)發(fā)的sql又沒(méi)有執(zhí)行過(guò)去,還是報(bào)臨時(shí)表空間不足,而臨時(shí)表空間釋放有需要時(shí)間,如果開(kāi)發(fā)的非常著急需要執(zhí)行sql。所以建議dba一次擴(kuò)容臨時(shí)表,擴(kuò)容大點(diǎn),
說(shuō)一下今天處理問(wèn)題的過(guò)程
1.查詢(xún)臨時(shí)表空間的使用率
select c.tablespace_name, to_char(c.bytes / 1024 / 1024 / 1024, '99,999.999') total_gb, to_char((c.bytes - d.bytes_used) / 1024 / 1024 / 1024, '99,999.999') free_gb, to_char(d.bytes_used / 1024 / 1024 / 1024, '99,999.999') use_gb, to_char(d.bytes_used * 100 / c.bytes, '99.99') || '%' use from (select tablespace_name, sum(bytes) bytes from dba_temp_files GROUP by tablespace_name) c, (select tablespace_name, sum(bytes_cached) bytes_used from v$temp_extent_pool GROUP by tablespace_name) d where c.tablespace_name = d.tablespace_name;
2.查詢(xún)那些用戶(hù)在使用
select a.username, a.sql_id, a.SEGTYPE, b.BYTES_USED/1024/1024/1024||'G', b.BYTES_FREE/1024/1024/1024 from V$TEMPSEG_USAGE a join V$TEMP_SPACE_HEADER b on a.TABLESPACE=b.tablespace_name;
解釋username 正在執(zhí)行sql的用戶(hù)名
sql_id
:正在執(zhí)行的sql的的sql_idsegtype
:正在執(zhí)行的SQL語(yǔ)句做的是什么操作BYTES_USED
:正在執(zhí)行sql語(yǔ)句使用的臨時(shí)表空間的大小BYTES_FREE
:剩余多少臨時(shí)表空間
大家可以看到這個(gè)臨時(shí)表空間的有6個(gè)數(shù)據(jù)文件,查詢(xún)的結(jié)果顯示按照每個(gè)臨時(shí)的數(shù)據(jù)文件使用了多少,還剩余多少,又又有一個(gè)問(wèn)題是第一用戶(hù)DBSNMP用戶(hù)已經(jīng)把臨時(shí)表空間占滿(mǎn)了那么第二個(gè)用戶(hù)還能使用這個(gè)六個(gè)數(shù)據(jù)文件的臨時(shí)表空間么,個(gè)人理解是六個(gè)數(shù)據(jù)文件中有第一個(gè)用戶(hù)在使用,也有第二個(gè)用戶(hù)在使用。
查詢(xún)實(shí)例中時(shí)候是否有大字段在使用臨時(shí)表空間:
select * ?from V$TEMPORARY_LOBS;
關(guān)于數(shù)據(jù)字典V$TEMP_SPACE_HEADER官方文檔的解釋?zhuān)?/strong>
V$TEMP_SPACE_HEADER 顯示每個(gè)LOCALLY MANAGED臨時(shí)表空間的每個(gè)文件的聚合信息,包括當(dāng)前正在使用的空間量以及空間頭中標(biāo)識(shí)的空閑量。
Column | Datatype | Description |
---|---|---|
TABLESPACE_NAME | VARCHAR2(30) | Name of the temporary tablespace |
FILE_ID | NUMBER | Absolute file number |
BYTES_USED | NUMBER | How many bytes are in use |
BLOCKS_USED | NUMBER | How many blocks are in use |
BYTES_FREE | NUMBER | How many bytes are free |
BLOCKS_FREE | NUMBER | How many blocks are free |
RELATIVE_FNO | NUMBER | The relative file number for the file |
關(guān)于V$TEMPSEG_USAGE的官方文檔的解釋?zhuān)?/strong>
V$TEMPSEG_USAGE 描述臨時(shí)段使用情況。
柱 | 數(shù)據(jù)類(lèi)型 | 描述 |
---|---|---|
USERNAME | VARCHAR2(30) | 請(qǐng)求臨時(shí)空間的用戶(hù) |
USER | VARCHAR2(30) | 此列已過(guò)時(shí)并維護(hù)以便向后兼容。 此列的值始終等于中的值 USERNAME 。 |
SESSION_ADDR | RAW(4 | 8) | 會(huì)話地址 |
SESSION_NUM | NUMBER | 會(huì)話序列號(hào) |
SQLADDR | RAW(4 | 8) | SQL語(yǔ)句的地址 |
SQLHASH | NUMBER | SQL語(yǔ)句的哈希值 |
SQL_ID | VARCHAR2(13) | SQL語(yǔ)句的SQL標(biāo)識(shí)符 |
TABLESPACE | VARCHAR2(31) | 分配空間的表空間 |
CONTENTS | VARCHAR2(9) | 指示表是否 TEMPORARY 或 PERMANENT |
SEGTYPE | VARCHAR2(9) | 排序類(lèi)型的類(lèi)型: SORT HASH DATA INDEX LOB_DATA LOB_INDEX |
SEGFILE# | NUMBER | 初始范圍的文件號(hào) |
SEGBLK# | NUMBER | 初始范圍的塊號(hào) |
EXTENTS | NUMBER | 分配給排序的范圍 |
BLOCKS | NUMBER | 分配給排序的塊中的范圍 |
SEGRFNO# | NUMBER | 初始范圍的相對(duì)文件號(hào) |
關(guān)于V$TEMP_EXTENT_POOL的官方文檔中的解釋
V$TEMP_EXTENT_POOL顯示緩存并用于實(shí)例的臨時(shí)空間的狀態(tài)。
請(qǐng)注意,臨時(shí)空間緩存的加載是惰性的,并且實(shí)例可以處于休眠狀態(tài)。
柱 | 數(shù)據(jù)類(lèi)型 | 描述 |
---|---|---|
TABLESPACE_NAME | VARCHAR2(30) | 表空間的名稱(chēng) |
FILE_ID | NUMBER | 絕對(duì)文件號(hào) |
EXTENTS_CACHED | NUMBER | 已緩存的范圍數(shù) |
EXTENTS_USED | NUMBER | 實(shí)際使用的范圍數(shù) |
BLOCKS_CACHED | NUMBER | 緩存的塊數(shù) |
BLOCKS_USED | NUMBER | 使用的塊數(shù) |
BYTES_CACHED | NUMBER | 緩存的字節(jié)數(shù) |
BYTES_USED | NUMBER | 使用的字節(jié)數(shù) |
RELATIVE_FNO | NUMBER | 相對(duì)文件號(hào) |
關(guān)于V$TEMPORARY_LOBS官方文檔解釋
V$TEMPORARY_LOBS 顯示臨時(shí)LOB。
柱 | 數(shù)據(jù)類(lèi)型 | 描述 |
---|---|---|
SID | NUMBER | 會(huì)話ID |
CACHE_LOBS | NUMBER | 緩存臨時(shí)LOB的數(shù)量 |
NOCACHE_LOBS | NUMBER | nocache臨時(shí)LOB的數(shù)量 |
ABSTRACT_LOBS | NUMBER | 抽象LOB的數(shù)量 |
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Navicat for oracle創(chuàng)建數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了Navicat for oracle創(chuàng)建數(shù)據(jù)庫(kù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11oracle中all、any函數(shù)用法與區(qū)別說(shuō)明
在Oracle中,any()表示括號(hào)內(nèi)任何一個(gè)條件,只要有一個(gè)滿(mǎn)足即可;而all()表示所有的條件都滿(mǎn)足才可以2023-04-04Oracle刪除重復(fù)的數(shù)據(jù),Oracle數(shù)據(jù)去重復(fù)
這篇文章主要介紹了Oracle刪除重復(fù)的數(shù)據(jù),Oracle數(shù)據(jù)去重復(fù),需要的朋友可以參考下2016-08-08