站長資訊網
        最全最豐富的資訊網站

        Oracle查看表空間使用率以及實例解決爆滿問題

        本篇文章給大家帶來了關于Oracle的相關知識,在日常的oralce使用中最長遇到的問題就是oralce的表空間滿了,數據無法寫入報錯,下面一起來看一下,希望對大家有幫助。

        Oracle查看表空間使用率以及實例解決爆滿問題

        推薦教程:《Oracle視頻教程》

        一、查看表空間使用率

        1.查看數據庫表空間文件:

        --查看數據庫表空間文件 select * from dba_data_files;

        2.查看所有表空間的總容量:

        --查看所有表空間的總容量 select dba.TABLESPACE_NAME, sum(bytes)/1024/1024 as MB   from dba_data_files dba  group by dba.TABLESPACE_NAME;

        3.查看數據庫表空間使用率

        --查看數據庫表空間使用率 select total.tablespace_name,round(total.MB, 2) as Total_MB,round(total.MB - free.MB, 2) as Used_MB,round((1-free.MB / total.MB)* 100, 2) || '%' as Used_Pct  from ( select tablespace_name, sum(bytes) /1024/1024 as MB  from dba_free_space group by tablespace_name) free, (select tablespace_name, sum(bytes) / 1024 / 1024 as MB  from dba_data_files group by tablespace_name) total      where free.tablespace_name = total.tablespace_name  order by used_pct desc;

        4.1.查看表空間總大小、使用率、剩余空間

        --查看表空間總大小、使用率、剩余空間 select a.tablespace_name, total, free, total-free as used, substr(free/total * 100, 1, 5) as "FREE%", substr((total - free)/total * 100, 1, 5) as "USED%" from (select tablespace_name, sum(bytes)/1024/1024 as total from dba_data_files group by tablespace_name) a, (select tablespace_name, sum(bytes)/1024/1024 as free from dba_free_space group by tablespace_name) b where a.tablespace_name = b.tablespace_name order by a.tablespace_name

        4.2.查看表空間使用率(包含temp臨時表空間)

        --查看表空間使用率(包含臨時表空間) select * from ( Select a.tablespace_name, (a.bytes- b.bytes) "表空間使用大小(BYTE)", a.bytes/(1024*1024*1024) "表空間大小(GB)", b.bytes/(1024*1024*1024) "表空間剩余大小(GB)", (a.bytes- b.bytes)/(1024*1024*1024) "表空間使用大小(GB)", to_char((1 - b.bytes/a.bytes)*100,'99.99999') || '%' "使用率" from (select tablespace_name, sum(bytes) bytes from dba_data_files group by tablespace_name) a, (select tablespace_name, sum(bytes) bytes from dba_free_space group by tablespace_name) b where a.tablespace_name = b.tablespace_name union all select c.tablespace_name, d.bytes_used "表空間使用大小(BYTE)", c.bytes/(1024*1024*1024) "表空間大小(GB)", (c.bytes-d.bytes_used)/(1024*1024*1024) "表空間剩余大小(GB)", d.bytes_used/(1024*1024*1024) "表空間使用大小(GB)", to_char(d.bytes_used*100/c.bytes,'99.99999') || '%' "使用率" 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 ) order by tablespace_name

        5.查看具體表的占用空間大小

        --查看具體表的占用空間大小 select * from ( select t.tablespace_name,t.owner, t.segment_name, t.segment_type, sum(t.bytes / 1024 / 1024) mb from dba_segments t where t.segment_type='TABLE' group by t.tablespace_name,t.OWNER, t.segment_name, t.segment_type ) t order by t.mb desc

        二、擴展大小或增加表空間文件

        1.更改表空間的dbf數據文件分配空間大小

        alter database datafile ‘...system_01.dbf' autoextend on; alter database datafile ‘...system_01.dbf' resize 1024M;

        2.1 為表空間新增一個數據文件(表空間滿32G不能擴展則增加表空間文件)

        alter tablespace SYSTEM add datafile '/****' size 1000m autoextend on next 100m;

        2.2 如果是temp臨時表新增表空間會報錯:

        0RA-03217: 變更TEMPORARY TABLESPACE 無效的選項

        解決方法: datafile改為tempfile

        alter tablespace TEMP01 add tempfile'/****' size 1000m autoextend on next 100m;

        針對temp臨時表空間使用率爆滿問題

        臨時表空間主要用途是在數據庫進行排序運算、管理索引、訪問視圖等操作時提供臨時的運算空間,當運算完成之后系統會自動清理,但有些時候我們會遇到臨時段沒有被釋放,TEMP表空間幾乎滿使用率情況;

        引起臨時表空間增大主要使用在以下幾種情況:

        1、order by or group by (disc sort占主要部分);

        2、索引的創建和重創建;

        3、distinct操作;

        4、union & intersect & minus sort-merge joins;

        5、Analyze 操作;

        6、有些異常也會引起TEMP的暴漲。

        解決方法一:用上述方法給temp增加表空間文件

        解決方法二:在服務器資源空間有限的情況下,重新建立新的臨時表空間替換當前的表空間

        --1.查看當前的數據庫默認表空間: select * from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';  --2.創建新的臨時表空間 create temporary tablespace TEMP01 tempfile  '/home/temp01.dbf' size 31G;  --3.更改默認臨時表空間 alter database default temporary tablespace TEMP01;  --4.刪除原來的臨時表空間 drop tablespace TEMP02 including contents and datafiles;  --如果刪除原來臨時表空間報錯ORA-60100:由于排序段,已阻止刪除表空間... --(說明有語句正在使用原來的臨時表空間,需要將其kill掉再刪除,此語句多為排序的語句) --查詢語句 Select se.username,se.sid,se.serial#,su.extents,su.blocks*to_number(rtrim(p.value))as Space, tablespace,segtype,sql_text from v$sort_usage su,v$parameter p,v$session se,v$sql s where p.name='db_block_size' and su.session_addr=se.saddr and s.hash_value=su.sqlhash and s.address=su.sqladdr order by se.username,se.sid;  --刪除對應的'sid,serial#' alter system kill session 'sid,serial#'

        附:查看表空間是否具有自動擴展的能力

        --查看表空間是否具有自動擴展的能力      SELECT T.TABLESPACE_NAME,D.FILE_NAME,      D.AUTOEXTENSIBLE,D.BYTES,D.MAXBYTES,D.STATUS      FROM DBA_TABLESPACES T,DBA_DATA_FILES D      WHERE T.TABLESPACE_NAME =D.TABLESPACE_NAME       ORDER BY TABLESPACE_NAME,FILE_NAME;

        推薦教程:《Oracle視頻教程》

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 97久久精品人人做人人爽| 国产精品久久久天天影视香蕉| 国产精品成人在线| 亚洲国产精品嫩草影院久久 | 国产精品美女网站在线观看| 国产精品成熟老女人视频| 夜夜爽一区二区三区精品| 国产精品美女久久久免费| 久久精品国产一区| 久久国产精品一国产精品金尊| 欧美久久亚洲精品| 精品露脸国产偷人在视频| 97视频在线精品国自产拍| 99热成人精品热久久669| 麻豆成人久久精品二区三区免费| 欧美日韩专区麻豆精品在线 | 成人国内精品久久久久影院| 无码久久精品国产亚洲Av影片| 欧美日韩精品一区二区三区不卡 | 日韩一区精品视频一区二区| 亚洲国产精品成人一区| 欧美午夜精品一区二区三区91 | 无码国产精品一区二区免费3p| 香港aa三级久久三级老师2021国产三级精品三级在| 丁香色婷婷国产精品视频| 亚洲天堂久久精品| 亚洲国语精品自产拍在线观看| 久久精品免费观看| 欧美精品国产一区二区| 四虎精品免费永久在线| 999久久久免费国产精品播放| 亚洲精品无码不卡| 国产A级毛片久久久精品毛片| 国产精品你懂的在线播放| 国产精品亚洲综合一区| 国产亚洲精品线观看动态图| 精品国产免费一区二区三区| 久久久久九九精品影院| 亚洲国产精品日韩| 亚洲欧洲成人精品香蕉网| 亚洲无线观看国产精品|