Home > Database > Mysql Tutorial > Oracle计算表所占用空间大小

Oracle计算表所占用空间大小

WBOY
Release: 2016-06-07 16:08:30
Original
1374 people have browsed it

在Oracle数据库中,如何计算一个表所占用的存储空间呢?我们可以通过系统视图DBA_SEGMENTS、USER_SEGMETNS、DBA_TABLES来查看一个

在Oracle数据库中,,如何计算一个表所占用的存储空间呢?我们可以通过系统视图DBA_SEGMENTS、USER_SEGMETNS、DBA_TABLES来查看一个表所占空间的大小,如下所示:

SELECT SEGMENT_NAME              TABLE_NAME
      ,SUM(BLOCKS)              BLOCKS
      ,SUM(BYTES)/(1024*1024)    "TABLE_SIZE[MB]"
FROM USER_SEGMENTS
WHERE  SEGMENT_TYPE='TABLE'
  AND SEGMENT_NAME=&TABLE_NAME
GROUP BY SEGMENT_NAME;
 
 
SELECT SEGMENT_NAME              TABLE_NAME
      ,SUM(BLOCKS)              BLOCKS
      ,SUM(BYTES)/(1024*1024)    "TABLE_SIZE[MB]"
FROM DBA_SEGMENTS
WHERE  SEGMENT_TYPE='TABLE'
  AND SEGMENT_NAME=&TABLE_NAME
GROUP BY SEGMENT_NAME;

注意,如果你通过系统视图DBA_TABELS、USER_TABLES统计、查看表所占的空间大小,那么由于统计信息过时或总是持续有DML操作(INSERTR、UPDATE、DELETE),那么有可能用下面SQL统计出的信息可能不准确。需要先收集一下表对象的统计信息。 另外,可能每个数据库的db_block_size有所不同,不一定是8192。所以注意修改.


ANALYZE TABLE OWNER.TABLE_NAME COMPUTE STATISTICS;
 

 
EXEC DBMS_STATS.GATHER_TABLE_STATS('OWNER','TABLE_NAME');
 
 
SELECT OWNER                    OWNER_NAME
      ,TABLE_NAME              TABLE_NAME
      ,TABLESPACE_NAME          TABLESPACE_NAME
      ,BLOCKS                  ACTUAL_BLOCKS
      ,BLOCKS + EMPTY_BLOCKS    TOTAL_BLOCKS
      ,(BLOCKS + EMPTY_BLOCKS) * 8192/(1024*1024)
                                "TABLE_SIZE[MB]"
FROM DBA_TABLES
WHERE OWNER=&OWNER
  AND TABLE_NAME=&TABLE_NAME

关于DBA_TABLES和DBA_SEGMENTS表中的block的区别,其实它们的关系如下所示:

      自动段空间管理(Automatic Segment Space Management ASSM)

              dba_segments.blocks = dba_tables.blocks + dba_tables.empty_blocks

      本地管理表空间(Locally Managed Tablespace )

              dba_segments.blocks = dba_tables.blocks + dba_tables.empty_blocks+ 1(SEGMENT HEADER BLOCK)

 

DBA_SEGMENTS.BLOCKS      holds the total number of blocks allocated to the table.

DBA_TABLES.BLOCKS        holds the total number of blocks allocated for data.

DBA_SEGMENTS中的blocks表示分配给表的存储空间,而DBA_TABLES中blocks表示表中数据实际占有的存储空间。所以这个是有细微差别的。所以你如果要查表的实际占用大小,那么就要使用DBA_TABLES来查询。查看数据库中占用存储空间从大到小的所有表对象


SELECT SEGMENT_NAME              TABLE_NAME
      ,SUM(BLOCKS)              BLOCKS
      ,SUM(BYTES)/(1024*1024)    "TABLE_SIZE[MB]"
FROM DBA_SEGMENTS
WHERE  SEGMENT_TYPE='TABLE'
GROUP BY SEGMENT_NAME
ORDER BY BLOCKS DESC;

本文永久更新链接地址:

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template