网站首页 > 技术文章 正文
一般来说,查表占据了多少的物理空间用的是dba_segments这个数据字典,这个数据字典展示了segment_type(段类型,如table,index,function,procedure 等等的段类型),bytes(段大小),blocks(段占用了多少个数据块)extents(分配了多少个区)等吧,信息很详细,可以直接select * from dba_segments;查看,用具有查看数据字典权限的用户查看。(给用户授予了SELECT_CATALOG_ROLE角色,普通用户就具有了查询数据字典的权限。)一般不要给普通用户dba角色,保持权限最小化原则。
1. 查看一般表的大小
select segment_name,segment_type,bytes/1024/1024 M from dba_segments where segment_name='SETTINGS#39; 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的方法就行,也是官方提供的。
猜你喜欢
- 2024-10-17 查看oracle用户权限 查看oracle用户有哪些权限
- 2024-10-17 修改oracle数据提示被用户锁住?别人正在用这个表?
- 2024-10-17 Oracle查询表英文名、表中文名、表业务描述、表记录数、字段数量
- 2024-10-17 Oracle如何创建只读用户 oracle只读表可以执行哪些命令
- 2024-10-17 数据库oracle常用字典表 oracle 字典表(dictionary)
- 2024-10-17 详解MySQL用户和权限管理--5大用户权限表、访问控制及权限管理
- 2024-10-17 Oracle表空间了解一下 oracle数据库表空间是什么
- 2024-10-17 运维必备:Oracle权限管理语句总结
- 2024-10-17 oracle 多表连接查询 join(一) oracle 多表联查
- 2024-10-17 新手之C#读取Oracle数据库中的表并显示
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)