电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Oracle查看表空間使用率以及爆滿解決方案詳解

瀏覽:135日期:2023-03-12 15:25:21
目錄
  • 一、查看表空間使用率
    • 1.查看數據庫表空間文件:
    • 2.查看所有表空間的總容量:
    • 3.查看數據庫表空間使用率
    • 4.1.查看表空間總大小、使用率、剩余空間
    • 4.2.查看表空間使用率(包含temp臨時表空間)
    • 5.查看具體表的占用空間大小
  • 二、擴展大小或增加表空間文件
    • 1.更改表空間的dbf數據文件分配空間大小
    • 2.1 為表空間新增一個數據文件(表空間滿32G不能擴展則增加表空間文件)
    • 2.2 如果是temp臨時表新增表空間會報錯:
  • 附:查看表空間是否具有自動擴展的能力
    • 總結

      一、查看表空間使用率

      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查看表空間使用率以及爆滿解決方案的文章就介紹到這了,更多相關Oracle查看表空間使用率內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

      標簽: Oracle
      主站蜘蛛池模板: 冷藏车-东风吸污车-纯电动环卫车-污水净化车-应急特勤保障车-程力专汽厂家-程力专用汽车股份有限公司销售二十一分公司 | 扬尘在线监测系统_工地噪声扬尘检测仪_扬尘监测系统_贝塔射线扬尘监测设备「风途物联网科技」 | 皮带机_移动皮带机_大倾角皮带机_皮带机厂家 - 新乡市国盛机械设备有限公司 | 咖啡加盟,咖啡店加盟连锁品牌-卡小逗 | 河北中仪伟创试验仪器有限公司是专业生产沥青,土工,水泥,混凝土等试验仪器的厂家,咨询电话:13373070969 | 精密交叉滚子轴承厂家,转盘轴承,YRT转台轴承-洛阳千协轴承 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 合景一建-无尘车间设计施工_食品医药洁净车间工程装修总承包公司 | 东莞市踏板石餐饮管理有限公司_正宗桂林米粉_正宗桂林米粉加盟_桂林米粉加盟费-东莞市棒子桂林米粉 | 酶联免疫分析仪-多管旋涡混合仪|混合器-莱普特科学仪器(北京)有限公司 | 河南中专学校|职高|技校招生-河南中职中专网 | 德州网站制作 - 网站建设设计 - seo排名优化 -「两山建站」 | 舞台木地板厂家_体育运动木地板_室内篮球馆木地板_实木运动地板厂家_欧氏篮球地板推荐 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 砖机托板价格|免烧砖托板|空心砖托板厂家_山东宏升砖机托板厂 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 定时排水阀/排气阀-仪表三通旋塞阀-直角式脉冲电磁阀-永嘉良科阀门有限公司 | 山东led显示屏,山东led全彩显示屏,山东LED小间距屏,临沂全彩电子屏-山东亚泰视讯传媒有限公司 | B2B网站_B2B免费发布信息网站_B2B企业贸易平台 - 企资网 | 方源木业官网-四川木门-全国木门专业品牌| 煤棒机_增碳剂颗粒机_活性炭颗粒机_木炭粉成型机-巩义市老城振华机械厂 | 上海三信|ph计|酸度计|电导率仪-艾科仪器 | 防渗土工膜|污水处理防渗膜|垃圾填埋场防渗膜-泰安佳路通工程材料有限公司 | 冷热冲击试验箱_温度冲击试验箱价格_冷热冲击箱排名_林频厂家 | 飞行者联盟-飞机模拟机_无人机_低空经济_航空技术交流平台 | SF6环境监测系统-接地环流在线监测装置-瑟恩实业 | 扬尘在线监测系统_工地噪声扬尘检测仪_扬尘监测系统_贝塔射线扬尘监测设备「风途物联网科技」 | 滚筒线,链板线,总装线,流水线-上海体能机电有限公司 | 钢结构厂房造价_钢结构厂房预算_轻钢结构厂房_山东三维钢结构公司 | 西安文都考研官网_西安考研辅导班_考研培训机构_西安在职考研培训 | 苏州西装定制-西服定制厂家-职业装定制厂家-尺品服饰西装定做公司 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 手术室净化装修-手术室净化工程公司-华锐手术室净化厂家 | 控显科技 - 工控一体机、工业显示器、工业平板电脑源头厂家 | 动物麻醉机-数显脑立体定位仪-北京易则佳科技有限公司 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 氧化铝球_高铝球_氧化铝研磨球-淄博誉洁陶瓷新材料有限公司 | 风电变桨伺服驱动器-风电偏航变桨系统-深圳众城卓越科技有限公司 | 分光色差仪,测色仪,反透射灯箱,爱色丽分光光度仪,美能达色差仪维修_苏州欣美和仪器有限公司 | 温州食堂承包 - 温州市尚膳餐饮管理有限公司 |