问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

oracle 怎样查询表空间大小和表空间

发布网友 发布时间:2022-04-22 21:45

我来回答

2个回答

懂视网 时间:2022-04-30 13:50

 转载自http://blog.csdn.net/cuker919/article/details/8514253

select segment_name, bytes as 大小
from user_segments
where segment_type = ‘TABLE‘ and segment_name in (‘VIEW_JLZDH_MP_DL_DAY_01‘,‘VIEW_JLZDH_MP_DL_DAY_02‘,‘VIEW_JLZDH_MP_DL_DAY_03‘,
‘VIEW_JLZDH_MP_DL_DAY_04‘,‘VIEW_JLZDH_MP_DL_DAY_05‘,‘VIEW_JLZDH_MP_DL_DAY_06‘,
‘VIEW_JLZDH_MP_DL_DAY_07‘,‘VIEW_JLZDH_MP_DL_DAY_08‘,‘VIEW_JLZDH_MP_DL_DAY_09‘,
‘VIEW_JLZDH_MP_DL_DAY_10‘,‘VIEW_JLZDH_MP_DL_DAY_11‘,‘VIEW_JLZDH_MP_DL_DAY_12‘)


select t.TABLE_NAME,t.NUM_ROWS from user_tables t where TABLE_NAME in (‘VIEW_JLZDH_MP_DL_DAY_01‘,‘VIEW_JLZDH_MP_DL_DAY_02‘,‘VIEW_JLZDH_MP_DL_DAY_03‘,
‘VIEW_JLZDH_MP_DL_DAY_04‘,‘VIEW_JLZDH_MP_DL_DAY_05‘,‘VIEW_JLZDH_MP_DL_DAY_06‘,
‘VIEW_JLZDH_MP_DL_DAY_07‘,‘VIEW_JLZDH_MP_DL_DAY_08‘,‘VIEW_JLZDH_MP_DL_DAY_09‘,
‘VIEW_JLZDH_MP_DL_DAY_10‘,‘VIEW_JLZDH_MP_DL_DAY_11‘,‘VIEW_JLZDH_MP_DL_DAY_12‘) order by t.TABLE_NAMe

 

有两种含义的表大小。一种是分配给一个表的物理空间数量,而不管空间是否被使用。可以这样查询获得字节数:

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.查看剩余表空间大小   SELECT tablespace_name 表空间,sum(blocks*8192/1000000) 剩余空间M FROM dba_free_space GROUP BY tablespace_name;   2.检查系统中所有表空间总体空间 select b.name,sum(a.bytes/1000000)总空间 from v$datafile a,v$tablespace b where a.ts#=b.ts# group by b.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
  上面描述中分别介绍了查看Oracle数据库中表空间信息的工具方法和命令方法。

 

  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数据库中数据文件信息的工具方法和命令方法。

 

  在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
  在上面介绍的方法中,建议掌握命令方法,因为你的环境可能没有图形工具,而SQLPLUS一般情况下都是可以使用的,有了命令脚本,很容易得到表空间和数据文件的相关信息。另外,数据库管理员应该多整理命令脚本,在需要时直接执行脚本以提高工作效率。

  在数据库管理员的日常工作中,应该经常查询表空间的利用率,按照数据库系统的具体情况估算表空间的增长量,当表空间的利用率超过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

在Oracle中查询表的大小、表的占用情况和表空间的大小

标签:

热心网友 时间:2022-04-30 10:58

查看所有表空间使用情况 :
select
b.file_id 文件ID号,
b.tablespace_name 表空间名,
b.bytes/1024/1024||'M'字节数,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024||'M' 已使用,
sum(nvl(a.bytes,0))/1024/1024||'M' 剩余空间,
100 - 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_id,b.bytes
order by b.file_id;
备注:建议用系统管理员dba权限进行查看。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
个达尔优破鼠标,请问怎么调才玩着顺 智能4k电视哪个牌子好 鼠标连点怎么破 破鼠标简直气死我了 三星4k电视使用一次光纤接口就坏了,怎么办? 破 鼠标!!是不是所有鼠标 只要稍微一接触不良 就停用 必须重起机子呢... 原装三星液晶屏4k惠普电视机多少钱 2015年欧元对换人民币汇率下滑到多少呢 2015年1月下旬欧元兑人民币汇率还能不能上涨 欧元兑换人民币汇率2015年3月份底会回到7吗? oracle 如何查看表空间最大的大小 如何查看oracle表空间已使用大小Select Segment 如何查看oracle剩余表空间 怎么查看oracle表空间,剩余大小,表空间利用 怎么查询oracle表空间总大小 怎么查看oracle数据库数据量大小? 怎么查看oracle表空间类型和大小? 如何查看oracle表空间已使用大小 华泰 网上交易系统 通达信版 专业版ii 哪个好 用华泰证券专业版二怎么提前设定卖出价? 华泰证券专业版2怎么 开两个 请问在华泰证券的专业版2里如何在选股平台中设置公式来选取在近期(N)内出现了周期(M)内最低价的股票? 华泰证券专业版2怎样查询个股 请问装Windows10后,华泰证券网上交易系统(专业版Ⅱ)能正常使用吗?_百 ... 华泰证券软件下载-华泰证券官网-华泰证券专业版2下载 华泰证券专业版2为什么不更新了? 华泰证券网上交易系统(专业版Ⅱ)V5.02 清洗猪肚应该加盐还是加醋?怎么洗猪肚才能没有异味? 华泰证券专业版ii~总是登陆不上去 华泰证券网上交易系统(专业版II)版中,如何取消掉“短线精灵”“所属版块”等子窗口 如何查看oracle表空间大小的使用情况 如何查看oracle中某个用户占用表空间大小情况 Oracle中如何查询所有表及其所使用的表空间 如何查看oracle所有的表空间? oracle数据中怎么查看表空间的名称及大小? 无DBA权限查看oracle表空间大小 如何在Oracle中查看各个表,表空间占用空间的大小 对比三组数据用什么图 怎么在PPT里面做柱状图,而且还要表示出百分比 在PPT中我们常用的图表种类分为几类 各自的优势是什么? PPT中两种颜色的柱形图如何做? PPT柱状图表如何美化? 2007ppt里面如何把一个图表的两个柱形不同单位分别计数? 厚棉衣的袖口蹭脏了,怎么洗? 冬天的棉衣领子和袖口很油腻,如何彻底洗干净? 羽绒服,棉服袖口,其他地方发黑,脏怎么清洗? 冬天的羽绒服袖口领口总是脏,有什么简单的办法可以清洗干净? 白色衣服的袖口特别容易脏,怎么洗 一到冬天羽绒服领口袖口就容易变脏,有什么办法可以防止这种情况?_百度... 羽绒服袖口和口袋的地方脏了很难洗,怎么办