成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle數據庫的表有多大呢?

數據庫 Oracle
一般來說,查表占據了多少的物理空間用的是dba_segments這個數據字典,這個數據字典展示了segment_type(段類型,如table,index,function,procedure 等等的段類型),bytes(段大小),blocks(段占用了多少個數據塊)extents(分配了多少個區)等吧,信息很詳細,可以直接select * from dba_segments;查看,用具有查看數據字典權限的用戶查看。

一般來說,查表占據了多少的物理空間用的是dba_segments這個數據字典,這個數據字典展示了segment_type(段類型,如table,index,function,procedure 等等的段類型),bytes(段大小),blocks(段占用了多少個數據塊)extents(分配了多少個區)等吧,信息很詳細,可以直接select * from dba_segments;查看,用具有查看數據字典權限的用戶查看。(給用戶授予了SELECT_CATALOG_ROLE角色,普通用戶就具有了查詢數據字典的權限。)一般不要給普通用戶dba角色,保持權限最小化原則。

 

[[336080]]

1. 查看一般表的大小

select segment_name,segment_type,bytes/1024/1024 M from dba_segments where segment_name='SETTINGS$' and segment_type='TABLE';

2. 查看帶有LOB字段的表的大小

LOB字段是有額外的專門區域存放,查看帶有LOB字段的表的大小比較復雜,分為了普通的字段大小,LOB字段大小,LOB索引字段大小,三個部分。

 

  1. SELECT (SELECT SUM(S.BYTES/1024/1024/1024)  
  2. -- The Table Segment size  
  3. FROM DBA_SEGMENTS S WHERE S.OWNER = UPPER('表的owner'AND (S.SEGMENT_NAME = UPPER('表名'))) + (SELECT  
  4. SUM(S.BYTES/1024/1024/1024)  
  5. -- The Lob Segment Size  
  6. FROM DBA_SEGMENTS S, DBA_LOBS L WHERE S.OWNER = UPPER('表的owner'AND (L.SEGMENT_NAME = S.SEGMENT_NAME AND L.TABLE_NAME = UPPER('表名'AND L.OWNER = 
  7.  
  8. UPPER('表的owner'))) + (SELECT SUM(S.BYTES/1024/1024/1024)  
  9. -- The Lob Index size  
  10. FROM DBA_SEGMENTS S, DBA_INDEXES I WHERE S.OWNER = UPPER('表的owner'AND  
  11. (I. INDEX_NAME = S.SEGMENT_NAME AND I.TABLE_NAME = UPPER('表名'AND INDEX_TYPE= 'LOB' AND I.OWNER = UPPER('表的owner'))) "TOTAL TABLE SIZE" FROM DUAL; 

詳細介紹內容可以查看Doc ID 118531.1

如果想查看這個庫里有多少個帶有LOB字段的表呢?通過dba_lobs可以查看。

例如:select distinct owner,table_name from dba_lobs where owner in ('***',’***’);

如果搜出幾百個幾千個LOB字段的表,一個個查大小,會很久…………

怎么把帶有LOB字段的表一次性列出來呢?

先創建一個臨時表:

  1. SQL> create table candidates (owner varchar2(30),segment_name varchar2(81)); 

再把上面查出來的帶有LOB字段的表插入進臨時表里:

  1. SQL> insert into candidates values ('owner','table_name'); 

然后利用游標:

 

  1. SQL> set serveroutput on  
  2. SQL> declare  
  3. cursor cur_temp is select owner, segment_name from candidates;  
  4. v_owner varchar2(30);  
  5. v_segment_name varchar2(81);  
  6. v_total_table_size number;  
  7. begin  
  8. open cur_temp;  
  9. fetch cur_temp into v_owner,v_segment_name;  
  10. while cur_temp%FOUND  
  11. loop  
  12. SELECT  
  13.  
  14. SELECT  
  15. nvl(SUM(S.BYTES/1024/1024/1024),0)  
  16. FROM  
  17. DBA_SEGMENTS S  
  18. WHERE  
  19. S.OWNER = UPPER(v_owner) AND  
  20. (S.SEGMENT_NAME = UPPER(v_segment_name)))  
  21.  
  22. (SELECT  
  23. nvl(SUM(S.BYTES/1024/1024/1024),0)  
  24. FROM  
  25. DBA_SEGMENTS S,  
  26. DBA_LOBS L  
  27. WHERE  
  28. S.OWNER = UPPER(v_owner) AND  
  29. (L.SEGMENT_NAME = S.SEGMENT_NAME AND L.TABLE_NAME = UPPER(v_segment_name) AND  
  30. L.OWNER = UPPER(v_owner))  
  31.  
  32.  
  33. (SELECT  
  34. nvl(SUM(S.BYTES/1024/1024/1024),0)  
  35. FROM  
  36. DBA_SEGMENTS S,  
  37. DBA_INDEXES I  
  38. WHERE  
  39. S.OWNER = UPPER(v_owner) AND  
  40. (I.INDEX_NAME = S.SEGMENT_NAME AND I.TABLE_NAME = UPPER(v_segment_name) AND INDEX_TYPE= 'LOB' AND I.OWNER = UPPER(v_owner))  
  41. "TOTAL TABLE SIZE" into v_total_table_size  
  42. FROM  
  43. DUAL;  
  44. DBMS_OUTPUT.PUT_LINE('Table '||v_segment_name||': '||v_total_table_size);  
  45. fetch cur_temp into v_owner,v_segment_name;  
  46. end loop;  
  47. end 

就會把帶有LOB字段的表大小都列出來了。

一般查大小就只查dba_segments了,查LOB的時候好像不多。偶爾查一下就用步驟2的方法就行,也是官方提供的。

責任編輯:未麗燕 來源: 今日頭條
相關推薦

2011-05-24 14:55:01

Oracle數據庫

2010-04-14 13:14:46

Oracle數據庫

2009-05-13 10:28:30

OracleDUAL數據庫

2011-04-08 16:00:11

Oracle數據庫外部表

2011-03-22 14:49:35

Oracle數據庫重定義表

2010-03-24 09:42:12

Oracle數據庫

2010-04-22 09:42:00

2010-05-19 17:35:35

2010-05-04 14:20:47

Oracle創建數據庫

2011-08-05 12:44:57

Oracle數據庫表空間

2011-08-29 18:17:12

Oracle聯合查詢

2011-03-17 16:35:20

Oracle數據庫段管理

2011-03-17 16:19:42

Oracle數據庫管理

2010-05-04 11:02:44

Oracle數據庫

2010-04-21 14:11:56

Oracle數據庫

2009-07-23 09:31:56

數據庫表連接方式

2011-05-26 09:08:31

Oracle數據庫

2011-05-19 13:25:14

Oracle數據庫

2011-03-16 08:54:45

Oracle數據庫索引

2010-04-23 09:23:44

Oracle 數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品一区二区三区 | 天堂综合网久久 | 伊人精品一区二区三区 | 天天草天天干 | 亚洲精品一区二区三区蜜桃久 | 成人毛片在线观看 | 久久久看 | 在线精品一区二区 | 国产99视频精品免费播放照片 | av小说在线| 亚洲午夜网 | 欧美激情网站 | av在线电影网站 | 精品视频久久久久久 | 久久久成人精品 | 欧美国产精品一区二区三区 | 亚洲国产专区 | 成人午夜免费福利视频 | 国产高清精品一区二区三区 | 久久国产成人 | a毛片| 欧美一区二区三区在线观看 | 综合久久久 | 中文字幕在线免费观看 | 特级生活片 | 国产午夜精品久久久久免费视高清 | 国产欧美一区二区三区日本久久久 | 在线看一区二区三区 | 国产毛片视频 | 日韩成人免费中文字幕 | 欧美电影在线观看网站 | 一区二区中文 | 久久久久久久一级 | 99精品国产一区二区三区 | 在线第一页 | 成人av一区二区亚洲精 | 亚洲成人一区二区三区 | 久久av.com | 日本成人福利视频 | 99国产精品久久久 | 国产精品久久午夜夜伦鲁鲁 |