日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

评估应用使用oracle磁盘空间,Oracle磁盘空间使用统计

發布時間:2024/9/15 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 评估应用使用oracle磁盘空间,Oracle磁盘空间使用统计 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

對于大型數據庫,Oracle占用的磁盤空間非常大,掌握數據庫中那些用戶、表占用了多殺磁盤空間,以及增長情況,可以方便日后對磁盤系統進行維護和擴充。

對Oracle磁盤空間使用情況,可以分為按照表空間、用戶或者表來進行統計。

(一)、表空間

計算表空間的剩余大小

select A.TABLESPACE_NAME,A.BYTES/(1024*1024*1024) "SPACE(G)", C.BYTES/(1024*1024) "FREE SPACE(M)",(C.BYTES*100)/A.BYTES "% FREE" FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_FREE C WHERE A.TABLESPACE_NAME=C.TABLESPACE_NAME;

或者select tablespace_name, sum(bytes)/(1024*1024*1024) "SPACE(G)" from dba_free_space group by tablespace_name;

(二)、用戶

計算每個用戶占用的磁盤空間select owner,sum(bytes)/1024/1024/1024 "Space(G)" from dba_segments group by owner order by 2;

計算某個用戶占用的磁盤空間select owner,sum(bytes)/1024/1024/1024 "Space(G)" from dba_segments where owner=‘LIAOJL‘ group by owner;

(三)、表

Oracle都是以段為存儲的,segment_name包含了表、索引、回滾段等,所以在dba_extents,dba_segments都可以找到占用空間大小的信息。select sum(bytes)/1024/1024 "Space(M)" from dba_extents where owner=‘LIAOJL‘ and segment_name=‘STUDENTS‘;

dba_segments也可以計算表的大小:select segment_name,bytes/1024/1024 "Space(MB)" from dba_segments where SEGMENT_TYPE=‘TABLE‘ and segment_name=upper(‘你要查找的表的名字‘);

當時上面的寫法不完全正確,當表是分區表,dba_segments有多條信息,可改成:select segment_name,sum(bytes)/1024/1024 "Space(MB)" from dba_segments where segment_name=upper(‘你要查找的表的名字‘);

上述方法對于一個很大的數據庫,SQL語句執行起來會很慢,而且消耗數據庫資源。Oracle支持對表進行分析,執行分析表操作后可以在dba_tables等系統表中查詢表大小、行數等信息,不過這些信息不是實時更新的,可以在數據庫空閑時,通過計劃任務來更新。

分析SQL方法:analyze table tab_name compute statistics;

表太大的話可以執行:analyze table tab_name estimate statistics;

/*SELECT tablespace_name, sum ( blocks ) as free_blk ,

trunc ( sum ( bytes ) /(1024*1024) ) as free_m,

max ( bytes ) / (1024) as big_chunk_k, count (*) as num_chunks

FROM dba_free_space GROUP BY tablespace_name;*/

/*

* SqlName: obj_seg

* 2006-11-17 By HuiYi

* 查詢對象大小

*/

select owner,sum(bytes)/1024/1024/1024 "Space(G)" from dba_segments group by owner order by 2 desc

col segment_name format a30

col segment_type format a15

col tablespace_name format a10

col bytes heading "Size(M)"

with t as(

select segment_name,owner,owner||‘.‘||segment_name,

segment_type,

tablespace_name,

bytes / 1024 / 1024 bytes

from dba_segments

where owner = upper(‘&user‘)

order by bytes desc

)

select * from t where rownum<10;

原文:http://my.oschina.net/u/133558/blog/512092

總結

以上是生活随笔為你收集整理的评估应用使用oracle磁盘空间,Oracle磁盘空间使用统计的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。