在Oracle中查询表的大小、表的占用情况和表空间的大小
有两种含义的表大小。一种是分配给一个表的物理空间数量,而不管空间是否被使用。可以这样查询获得字节数:
select segment_name, bytes
from user_segments
where segment_type = 'TABLE';
或者
Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name
另一种表实际使用的空间。这样查询:
analyze table emp compute statistics;
select num_rows * avg_row_len
from user_tables
where table_name = 'EMP';
查看每个表空间的大小
Select Tablespace_Name,Sum(bytes)/1024/1024 From Dba_Segments Group By Tablespace_Name
1、查看Oracle数据库中表空间信息的工具方法:
使用oracle enterprise manager console工具,这是oracle的客户端工具,当安装oracle服务器或客户端时会自动安装此工具,在windows操作系统上完成oracle安装后,通过下面的方法登录该工具:开始菜单——程序——Oracle-OraHome92——Enterprise Manager Console(单击)——oracle enterprise manager console登录——选择‘独立启动’单选框——‘确定’ —— ‘oracle enterprise manager console,独立’ ——选择要登录的‘实例名’ ——弹出‘数据库连接信息’ ——输入’用户名/口令’ (一般使用sys用户),’连接身份’选择选择SYSDBA——‘确定’,这时已经成功登录该工具,选择‘存储’ ——表空间,会看到如下的界面,该界面显示了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间大小,已使用的表空间大小及表空间利用率。
图1 表空间大小及使用率
2、查看Oracle数据库中表空间信息的命令方法:
通过查询数据库系统中的数据字典表(data dictionary tables)获取表空间的相关信息,首先使用客户端工具连接到数据库,这些工具可以是SQLPLUS字符工具、TOAD、PL/SQL等,连接到数据库后执行如下的查询语句:
select
a.a1 表空间名称,
c.c2 类型,
c.c3 区管理,
b.b2/1024/1024 表空间大小M,
(b.b2-a.a2)/1024/1024 已使用M,
substr((b.b2-a.a2)/b.b2*100,1,5) 利用率
from
(select tablespace_name a1, sum(nvl(bytes,0)) a2 from dba_free_space group by tablespace_name) a,
(select tablespace_name b1,sum(bytes) b2 from dba_data_files group by tablespace_name) b,
(select tablespace_name c1,contents c2,extent_management c3 from dba_tablespaces) c
where a.a1=b.b1 and c.c1=b.b1;
该语句通过查询dba_free_space,dba_data_files,dba_tablespaces这三个数据字典表,得到了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间大小,已使用的表空间大小及表空间利用率。dba_free_space表描述了表空间的空闲大小,dba_data_files表描述了数据库中的数据文件,dba_tablespaces表描述了数据库中的表空间。
上面语句中from子句后有三个select语句,每个select语句相当于一个视图,视图的名称分别为a、b、c,通过它们之间的关联关系,我们得到了表空间的相关信息。
语句执行结果如下:
表空间名称
|
类型
|
区管理
|
表空间大小M
|
已使用M
|
利用率
|
CWMLITE
|
PERMANENT
|
LOCAL
|
20
|
9.375
|
46.87
|
DRSYS
|
PERMANENT
|
LOCAL
|
20
|
9.6875
|
48.43
|
EXAMPLE
|
PERMANENT
|
LOCAL
|
149.375
|
149.25
|
99.91
|
INDX
|
PERMANENT
|
LOCAL
|
25
|
0.0625
|
0.25
|
ODM
|
PERMANENT
|
LOCAL
|
20
|
9.375
|
46.87
|
SYSTEM
|
PERMANENT
|
LOCAL
|
400
|
397.375
|
99.34
|
TOOLS
|
PERMANENT
|
LOCAL
|
10
|
6.0625
|
60.62
|
UNDOTBS1
|
UNDO
|
LOCAL
|
200
|
5.9375
|
2.968
|
USERS
|
PERMANENT
|
LOCAL
|
25
|
0.0625
|
0.25
|
XDB
|
PERMANENT
|
LOCAL
|
38.125
|
37.9375
|
99.5
|
1、查看Oracle数据库中数据文件信息的工具方法:
使用上面介绍过的方法登录oracle enterprise manager console工具,选择‘存储’ ——数据文件,会看到如下的界面,该界面显示了数据文件名称,表空间名称,以”兆”为单位的数据文件大小,已使用的数据文件大小及数据文件利用率。
图2 数据文件大小及使用率
2、查看Oracle数据库中数据文件信息的命令方法:
通过查询数据库系统中的数据字典表(data dictionary tables)获取数据文件的相关信息,首先使用客户端工具连接到数据库,这些工具可以是SQLPLUS字符工具、TOAD、PL/SQL等,连接到数据库后执行如下的查询语句:
select
b.file_name 物理文件名,
b.tablespace_name 表空间,
b.bytes/1024/1024 大小M,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024 已使用M,
substr((b.bytes-sum(nvl(a.bytes,0)))/(b.bytes)*100,1,5) 利用率
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_name,b.bytes
order by b.tablespace_name
语句执行结果如下:
物理文件名
|
表空间
|
大小M
|
已使用M
|
利用率
|
G:/ORACLE/ORADATA/ORA92/CWMLITE01.DBF
|
CWMLITE
|
20
|
9.375
|
46.87
|
G:/ORACLE/ORADATA/ORA92/DRSYS01.DBF
|
DRSYS
|
20
|
9.6875
|
48.43
|
G:/ORACLE/ORADATA/ORA92/EXAMPLE01.DBF
|
EXAMPLE
|
149.375
|
149.25
|
99.91
|
G:/ORACLE/ORADATA/ORA92/INDX01.DBF
|
INDX
|
25
|
0.0625
|
0.25
|
G:/ORACLE/ORADATA/ORA92/ODM01.DBF
|
ODM
|
20
|
9.375
|
46.87
|
G:/ORACLE/ORADATA/ORA92/SYSTEM01.DBF
|
SYSTEM
|
400
|
397.375
|
99.34
|
G:/ORACLE/ORADATA/ORA92/TOOLS01.DBF
|
TOOLS
|
10
|
6.0625
|
60.62
|
G:/ORACLE/ORADATA/ORA92/UNDOTBS01.DBF
|
UNDOTBS1
|
200
|
5.9375
|
2.968
|
G:/ORACLE/ORADATA/ORA92/USERS01.DBF
|
USERS
|
25
|
0.0625
|
0.25
|
G:/ORACLE/ORADATA/ORA92/XDB01.DBF
|
XDB
|
38.125
|
37.9375
|
99.5
|
在oracle数据库中,临时表空间主要用于用户在使用order by 、group by语句进行排序和汇总时所需的临时工作空间。要查询数据库中临时表空间的名称,大小及数据文件,可以查询数据字典dba_tablespaces及dba_data_files。命令如下:
select
a.talbespace_name 表空间名称,
b.bytes 大小bytes,
b.file_name 数据文件名
from dba_tablespaces a, dba_data_files b
Where a.talbespace_name=b.talbespace_name and a.contents=’TEMPORARY’;
查询结果如下:
表空间名称大小bytes数据文件名
TEMPONLINEG:/ORACLE/ORADATA/ORA92/TEMP01.DBF
从oracle 9i开始,可以创建Temporary tablespace类表空间,即“临时“表空间,这类表空间使用临时文件。临时文件的信息被存储在数据字典V$tempfile中。命令如下:
Select file#,status,name from V$tempfile;
查询数据字典V$tempfile结果如下:
FILE#
|
status
|
NAME
|
1
|
ONLINE
|
G:/ORACLE/ORADATA/ORA92/TEMP01.DBF
|
在数据库管理员的日常工作中,应该经常查询表空间的利用率,按照数据库系统的具体情况估算表空间的增长量,当表空间的利用率超过90%时,要及时采取措施,如清理历史表、历史数据以释放空间,向表空间中添加新的数据文件,扩展现有数据文件大小等方法来降低表空间的利用率,避免表空间利用率接近100%时,将产生空间不够的错误。
1.查询oracle表空间的使用情况
select b.file_id 文件ID,
b.tablespace_name 表空间,
b.file_name 物理文件名,
b.bytes 总字节数,
(b.bytes-sum(nvl(a.bytes,0))) 已使用,
sum(nvl(a.bytes,0)) 剩余,
sum(nvl(a.bytes,0))/(b.bytes)*100 剩余百分比
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_name,b.file_id,b.bytes
order by b.tablespace_name
2.查询oracle系统用户的默认表空间和临时表空间
select default_tablespace,temporary_tablespace from dba_users
3.查询单张表的使用情况
select segment_name,bytes from dba_segments where segment_name = 'RE_STDEVT_FACT_DAY' and owner = USER
RE_STDEVT_FACT_DAY是您要查询的表名称
4.查询所有用户表使用大小的前三十名
select * from (select segment_name,bytes from dba_segments where owner = USER order by bytes desc ) where rownum <= 30
5.查询当前用户默认表空间的使用情况
select tablespacename,sum(totalContent),sum(usecontent),sum(sparecontent),avg(sparepercent)
from
(
SELECT b.file_id as id,b.tablespace_name as tablespacename,b.bytes as totalContent,(b.bytes-sum(nvl(a.bytes,0))) as usecontent,sum(nvl(a.bytes,0)) as sparecontent,sum(nvl(a.bytes,0))/(b.bytes)*100 as sparepercent
FROM dba_free_space a,dba_data_files b
WHERE a.file_id=b.file_id and b.tablespace_name = (select default_tablespace from dba_users where username = user)
group by b.tablespace_name,b.file_name,b.file_id,b.bytes
)
GROUP BY tablespacename
6.查询用户表空间的表
select * from user_tables
有两种含义的表大小。一种是分配给一个表的物理空间数量,而不管空间是否被使用。可以这样查询获得字节数:
select segment_name, bytes
from user_segments
where segment_type = 'TABLE';
或者
Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name
另一种表实际使用的空间。这样查询:
analyze table emp compute statistics;
select num_rows * avg_row_len
from user_tables
where table_name = 'EMP';
查看每个表空间的大小
Select Tablespace_Name,Sum(bytes)/1024/1024 From Dba_Segments Group By Tablespace_Name
1、查看Oracle数据库中表空间信息的工具方法:
使用oracle enterprise manager console工具,这是oracle的客户端工具,当安装oracle服务器或客户端时会自动安装此工具,在windows操作系统上完成oracle安装后,通过下面的方法登录该工具:开始菜单——程序——Oracle-OraHome92——Enterprise Manager Console(单击)——oracle enterprise manager console登录——选择‘独立启动’单选框——‘确定’ —— ‘oracle enterprise manager console,独立’ ——选择要登录的‘实例名’ ——弹出‘数据库连接信息’ ——输入’用户名/口令’ (一般使用sys用户),’连接身份’选择选择SYSDBA——‘确定’,这时已经成功登录该工具,选择‘存储’ ——表空间,会看到如下的界面,该界面显示了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间大小,已使用的表空间大小及表空间利用率。
图1 表空间大小及使用率
2、查看Oracle数据库中表空间信息的命令方法:
通过查询数据库系统中的数据字典表(data dictionary tables)获取表空间的相关信息,首先使用客户端工具连接到数据库,这些工具可以是SQLPLUS字符工具、TOAD、PL/SQL等,连接到数据库后执行如下的查询语句:
select
a.a1 表空间名称,
c.c2 类型,
c.c3 区管理,
b.b2/1024/1024 表空间大小M,
(b.b2-a.a2)/1024/1024 已使用M,
substr((b.b2-a.a2)/b.b2*100,1,5) 利用率
from
(select tablespace_name a1, sum(nvl(bytes,0)) a2 from dba_free_space group by tablespace_name) a,
(select tablespace_name b1,sum(bytes) b2 from dba_data_files group by tablespace_name) b,
(select tablespace_name c1,contents c2,extent_management c3 from dba_tablespaces) c
where a.a1=b.b1 and c.c1=b.b1;
该语句通过查询dba_free_space,dba_data_files,dba_tablespaces这三个数据字典表,得到了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间大小,已使用的表空间大小及表空间利用率。dba_free_space表描述了表空间的空闲大小,dba_data_files表描述了数据库中的数据文件,dba_tablespaces表描述了数据库中的表空间。
上面语句中from子句后有三个select语句,每个select语句相当于一个视图,视图的名称分别为a、b、c,通过它们之间的关联关系,我们得到了表空间的相关信息。
语句执行结果如下:
表空间名称
|
类型
|
区管理
|
表空间大小M
|
已使用M
|
利用率
|
CWMLITE
|
PERMANENT
|
LOCAL
|
20
|
9.375
|
46.87
|
DRSYS
|
PERMANENT
|
LOCAL
|
20
|
9.6875
|
48.43
|
EXAMPLE
|
PERMANENT
|
LOCAL
|
149.375
|
149.25
|
99.91
|
INDX
|
PERMANENT
|
LOCAL
|
25
|
0.0625
|
0.25
|
ODM
|
PERMANENT
|
LOCAL
|
20
|
9.375
|
46.87
|
SYSTEM
|
PERMANENT
|
LOCAL
|
400
|
397.375
|
99.34
|
TOOLS
|
PERMANENT
|
LOCAL
|
10
|
6.0625
|
60.62
|
UNDOTBS1
|
UNDO
|
LOCAL
|
200
|
5.9375
|
2.968
|
USERS
|
PERMANENT
|
LOCAL
|
25
|
0.0625
|
0.25
|
XDB
|
PERMANENT
|
LOCAL
|
38.125
|
37.9375
|
99.5
|
1、查看Oracle数据库中数据文件信息的工具方法:
使用上面介绍过的方法登录oracle enterprise manager console工具,选择‘存储’ ——数据文件,会看到如下的界面,该界面显示了数据文件名称,表空间名称,以”兆”为单位的数据文件大小,已使用的数据文件大小及数据文件利用率。
图2 数据文件大小及使用率
2、查看Oracle数据库中数据文件信息的命令方法:
通过查询数据库系统中的数据字典表(data dictionary tables)获取数据文件的相关信息,首先使用客户端工具连接到数据库,这些工具可以是SQLPLUS字符工具、TOAD、PL/SQL等,连接到数据库后执行如下的查询语句:
select
b.file_name 物理文件名,
b.tablespace_name 表空间,
b.bytes/1024/1024 大小M,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024 已使用M,
substr((b.bytes-sum(nvl(a.bytes,0)))/(b.bytes)*100,1,5) 利用率
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_name,b.bytes
order by b.tablespace_name
语句执行结果如下:
物理文件名
|
表空间
|
大小M
|
已使用M
|
利用率
|
G:/ORACLE/ORADATA/ORA92/CWMLITE01.DBF
|
CWMLITE
|
20
|
9.375
|
46.87
|
G:/ORACLE/ORADATA/ORA92/DRSYS01.DBF
|
DRSYS
|
20
|
9.6875
|
48.43
|
G:/ORACLE/ORADATA/ORA92/EXAMPLE01.DBF
|
EXAMPLE
|
149.375
|
149.25
|
99.91
|
G:/ORACLE/ORADATA/ORA92/INDX01.DBF
|
INDX
|
25
|
0.0625
|
0.25
|
G:/ORACLE/ORADATA/ORA92/ODM01.DBF
|
ODM
|
20
|
9.375
|
46.87
|
G:/ORACLE/ORADATA/ORA92/SYSTEM01.DBF
|
SYSTEM
|
400
|
397.375
|
99.34
|
G:/ORACLE/ORADATA/ORA92/TOOLS01.DBF
|
TOOLS
|
10
|
6.0625
|
60.62
|
G:/ORACLE/ORADATA/ORA92/UNDOTBS01.DBF
|
UNDOTBS1
|
200
|
5.9375
|
2.968
|
G:/ORACLE/ORADATA/ORA92/USERS01.DBF
|
USERS
|
25
|
0.0625
|
0.25
|
G:/ORACLE/ORADATA/ORA92/XDB01.DBF
|
XDB
|
38.125
|
37.9375
|
99.5
|
在oracle数据库中,临时表空间主要用于用户在使用order by 、group by语句进行排序和汇总时所需的临时工作空间。要查询数据库中临时表空间的名称,大小及数据文件,可以查询数据字典dba_tablespaces及dba_data_files。命令如下:
select
a.talbespace_name 表空间名称,
b.bytes 大小bytes,
b.file_name 数据文件名
from dba_tablespaces a, dba_data_files b
Where a.talbespace_name=b.talbespace_name and a.contents=’TEMPORARY’;
查询结果如下:
表空间名称大小bytes数据文件名
TEMPONLINEG:/ORACLE/ORADATA/ORA92/TEMP01.DBF
从oracle 9i开始,可以创建Temporary tablespace类表空间,即“临时“表空间,这类表空间使用临时文件。临时文件的信息被存储在数据字典V$tempfile中。命令如下:
Select file#,status,name from V$tempfile;
查询数据字典V$tempfile结果如下:
FILE#
|
status
|
NAME
|
1
|
ONLINE
|
G:/ORACLE/ORADATA/ORA92/TEMP01.DBF
|
在数据库管理员的日常工作中,应该经常查询表空间的利用率,按照数据库系统的具体情况估算表空间的增长量,当表空间的利用率超过90%时,要及时采取措施,如清理历史表、历史数据以释放空间,向表空间中添加新的数据文件,扩展现有数据文件大小等方法来降低表空间的利用率,避免表空间利用率接近100%时,将产生空间不够的错误。
1.查询oracle表空间的使用情况
select b.file_id 文件ID,
b.tablespace_name 表空间,
b.file_name 物理文件名,
b.bytes 总字节数,
(b.bytes-sum(nvl(a.bytes,0))) 已使用,
sum(nvl(a.bytes,0)) 剩余,
sum(nvl(a.bytes,0))/(b.bytes)*100 剩余百分比
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_name,b.file_id,b.bytes
order by b.tablespace_name
2.查询oracle系统用户的默认表空间和临时表空间
select default_tablespace,temporary_tablespace from dba_users
3.查询单张表的使用情况
select segment_name,bytes from dba_segments where segment_name = 'RE_STDEVT_FACT_DAY' and owner = USER
RE_STDEVT_FACT_DAY是您要查询的表名称
4.查询所有用户表使用大小的前三十名
select * from (select segment_name,bytes from dba_segments where owner = USER order by bytes desc ) where rownum <= 30
5.查询当前用户默认表空间的使用情况
select tablespacename,sum(totalContent),sum(usecontent),sum(sparecontent),avg(sparepercent)
from
(
SELECT b.file_id as id,b.tablespace_name as tablespacename,b.bytes as totalContent,(b.bytes-sum(nvl(a.bytes,0))) as usecontent,sum(nvl(a.bytes,0)) as sparecontent,sum(nvl(a.bytes,0))/(b.bytes)*100 as sparepercent
FROM dba_free_space a,dba_data_files b
WHERE a.file_id=b.file_id and b.tablespace_name = (select default_tablespace from dba_users where username = user)
group by b.tablespace_name,b.file_name,b.file_id,b.bytes
)
GROUP BY tablespacename
6.查询用户表空间的表
select * from user_tables
相关推荐
2. **使用DBMS_SPACE.TOTAL_SPACE**:这是一个Oracle提供的包,可以用来查询表空间中使用的空间大小。例如: ```sql SELECT DBMS_SPACE.TOTAL_SPACE('FILE_LOG') AS total_space; ``` 3. **使用DBMS_SPACE.COUNT...
帮助您查看oracle的表空间大小,已使用百分比,剩余大小,总大小,表空间名
### Oracle查看各表占用空间 ...综上所述,通过上述SQL查询语句,我们可以有效地获取Oracle数据库中特定用户在特定表空间下的所有表所占用的空间大小。这对于数据库管理员来说是一项非常实用且重要的技能。
1、当前登录用户,所有表占用表空间情况,提供合计 和 明细查询,显示为M; 2、查看某个用户所有表各自占用表空间的大小,并显示各表数据的条数;——常用于清表前,确认选最多记录的先清; 3、全数据库查询所有表...
### Oracle查询表碎片知识点详解 在Oracle数据库管理与优化的过程中,了解并处理表碎片是非常重要的一个环节。本文将详细介绍如何通过SQL查询来检测Oracle表的碎片情况,并对给出的SQL查询语句进行深入解析。 ####...
在Oracle数据库管理过程中,合理地管理和优化存储空间是非常重要的工作之一。有时,我们会遇到这样的情况:某个表空间占用的实际物理空间远大于其实际需要的空间,这不仅造成了存储资源的浪费,也可能会影响到其他表...
Oracle数据库系统中,Temp表空间是用于存储临时段的地方,主要在执行排序、连接和创建索引等操作时使用。当遇到"Oracle temp表空间不足"的问题时,这通常意味着数据库运行过程中产生的临时数据超过了现有Temp表空间...
这里使用了`dba_free_space`视图来查询表空间中的空闲区域。通过求和每个表空间中的空闲空间并转换为MB,我们可以得出每个表空间已被使用的空间大小。 #### 四、计算表空间的使用情况 要获得每个表空间的使用详情...
` 这条语句可以统计每个表空间未被使用的空间大小和块数,对于容量规划和性能调优至关重要。 - **表空间对应的数据文件**:`SELECT * FROM dba_data_files WHERE tablespace_name = 'RBS';` 这个查询用于找出特定表...
然而,在某些情况下,这个任务可能过于频繁地运行,导致在SYSAUX表空间中积累了大量的顾问输出和相关对象,从而占用大量空间。 **解决方案** 解决SYSAUX表空间过大的问题有几种方法: 1. **调整统计信息顾问频率*...
查看oracle表空间和临时表空间的使用情况、当前用户下的表所占空间大小表空间物理文件的名称和大小,是oracle DBA的利器哦
oracle表数据已经删除,但是表空间不能释放的情况;支持查询单表占用空间大小,释放掉占用的无效空间;支持批量生成释放脚本,释放掉空表占用的表空间;
3. **具体应用**:此查询可以用来找出占用空间较大的段,从而有助于进行进一步的空间管理和优化工作。 #### 三、查看某个表空间内最大连续的自由空间大小 **脚本:** ```sql SELECT tablespace_name, max(bytes) ...
本文介绍了Oracle数据库中关于表空间的一些基本操作,包括创建表空间、查询表空间使用情况、扩展表空间、重命名表空间等。通过这些操作,可以有效地管理和优化Oracle数据库的存储空间,提高系统的稳定性和性能。在...
1. **查询表空间的总大小和使用情况**: ```sql SELECT tablespace_name, SUM(bytes) / (1024 * 1024) "Total MB", SUM(bytes - (blocks - bm.blocks) * 8192) / (1024 * 1024) "Free MB" FROM dba_free_space ...
在Oracle数据库管理中,了解如何查看表空间表信息是一项重要的技能。这有助于DBA(数据库管理员)或开发人员更好地理解数据库结构、优化查询性能以及进行必要的维护工作。 #### 标题:Oracle查看表空间表信息 此...
Oracle 临时表空间是Oracle数据库管理系统中的一个重要组成部分,主要用于存储执行特定操作时产生的临时数据,例如排序、连接和聚合操作。这些操作在处理大量数据时尤为常见,因此了解临时表空间的使用注意事项对于...
### 关于Oracle释放过度使用的Undo表空间的知识点 在Oracle数据库管理中,Undo表空间扮演着...在日常运维中,建议定期检查Undo表空间的使用情况,并根据实际情况采取相应的措施,以确保数据库系统的稳定性和高效性。
在Oracle数据库管理中,了解表空间的大小及使用情况至关重要,因为这有助于监控数据库的存储利用率,及时规划和调整存储分配。以下是一些用于检查Oracle表空间状态的关键SQL语句,以及它们的功能详解: 1. **查看表...