您现在的位置是:亿华云 > IT科技类资讯
Oracle数据库的表有多大呢?
亿华云2025-10-09 09:12:18【IT科技类资讯】9人已围观
简介一般来说,查表占据了多少的物理空间用的是dba_segments这个数据字典,这个数据字典展示了segment_type(段类型,如table,index,function,procedure 等等的
一般来说,数据查表占据了多少的数据物理空间用的是dba_segments这个数据字典,这个数据字典展示了segment_type(段类型,数据如table,数据index,数据function,数据procedure 等等的数据段类型),bytes(段大小),数据blocks(段占用了多少个数据块)extents(分配了多少个区)等吧,数据信息很详细,数据可以直接select * from dba_segments;查看,数据用具有查看数据字典权限的数据用户查看。(给用户授予了SELECT_CATALOG_ROLE角色,数据普通用户就具有了查询数据字典的数据权限。)一般不要给普通用户dba角色,b2b供应网数据保持权限最小化原则。

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索引字段大小,三个部分。
SELECT (SELECT SUM(S.BYTES/1024/1024/1024) -- The Table Segment size FROM DBA_SEGMENTS S WHERE S.OWNER = UPPER(表的owner) AND (S.SEGMENT_NAME = UPPER(表名))) + (SELECT SUM(S.BYTES/1024/1024/1024) -- The Lob Segment Size 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 = UPPER(表的owner))) + (SELECT SUM(S.BYTES/1024/1024/1024) -- The Lob Index size FROM DBA_SEGMENTS S, DBA_INDEXES I WHERE S.OWNER = UPPER(表的owner) AND (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字段的表一次性列出来呢?
先创建一个临时表:
SQL> create table candidates (owner varchar2(30),segment_name varchar2(81));再把上面查出来的带有LOB字段的表插入进临时表里:
SQL> insert into candidates values (owner,table_name);然后利用游标:
SQL> set serveroutput on SQL> declare cursor cur_temp is select owner, segment_name from candidates; v_owner varchar2(30); v_segment_name varchar2(81); v_total_table_size number; begin open cur_temp; fetch cur_temp into v_owner,v_segment_name; while cur_temp%FOUND loop SELECT ( SELECT nvl(SUM(S.BYTES/1024/1024/1024),0) FROM DBA_SEGMENTS S WHERE S.OWNER = UPPER(v_owner) AND (S.SEGMENT_NAME = UPPER(v_segment_name))) + (SELECT nvl(SUM(S.BYTES/1024/1024/1024),0) FROM DBA_SEGMENTS S, DBA_LOBS L WHERE S.OWNER = UPPER(v_owner) AND (L.SEGMENT_NAME = S.SEGMENT_NAME AND L.TABLE_NAME = UPPER(v_segment_name) AND L.OWNER = UPPER(v_owner)) ) + (SELECT nvl(SUM(S.BYTES/1024/1024/1024),0) FROM DBA_SEGMENTS S, DBA_INDEXES I WHERE S.OWNER = UPPER(v_owner) AND (I.INDEX_NAME = S.SEGMENT_NAME AND I.TABLE_NAME = UPPER(v_segment_name) AND INDEX_TYPE= LOB AND I.OWNER = UPPER(v_owner)) ) "TOTAL TABLE SIZE" into v_total_table_size FROM DUAL; DBMS_OUTPUT.PUT_LINE(Table ||v_segment_name||: ||v_total_table_size); fetch cur_temp into v_owner,v_segment_name; end loop; end; /就会把带有LOB字段的表大小都列出来了。
一般查大小就只查dba_segments了,查LOB的时候好像不多。偶尔查一下就用步骤2的方法就行,也是官方提供的。
b2b信息网很赞哦!(9)
相关文章
- 4、企业无形资产:通用网站已成为企业网络知识产权的重要组成部分,属于企业的无形资产,也有助于提升企业的品牌形象和技术领先形象。它是企业品牌资产不可或缺的一部分。
- MIT开发Twist编程语言:专门解决量子计算数据纠缠问题
- 2022年现代Python编程的四个关键点
- 春节找点乐子来写个烟花动效吧
- 为了避免将来给我们的个人站长带来的麻烦,在选择域名后缀时,我们的站长最好省略不稳定的后缀域名,比如n,因为我们不知道策略什么时候会改变,更不用说我们将来是否还能控制这个域名了。因此,如果站长不是企业,或者有选择的话,如果不能选择域名的cn类,最好不要选择它。
- Flowable 流程实例的挂起(暂停)与激活
- Java 写出来的短信转发器,希望能成为你的日常小助手
- 你以为的万能爬虫方法,其实一行代码就能识别!
- 四、配置网站,填充内容
- 8 个令人惊叹的 Vue.js UI 组件,说不定用得上!