ORACLE查看表空间

//剩余表空间大小
SELECT SUM(bytes) / (1024 * 1024) AS free_space, tablespace_name
FROM dba_free_space
GROUP BY tablespace_name;

//表空间大小,已使用,剩余,使用率,剩余率
SELECT a.tablespace_name,
a.bytes total,
b.bytes used,
c.bytes free,
(b.bytes * 100) / a.bytes “% USED “,
(c.bytes * 100) / a.bytes “% FREE ”
FROM sys.sm tsavaila,sys.sm ts_used b, sys.sm$ts_free c
WHERE a.tablespace_name = b.tablespace_name
AND a.tablespace_name = c.tablespace_name;

–查询表空间使用情况
SELECT UPPER(F.TABLESPACE_NAME) “表空间名”,
D.TOT_GROOTTE_MB “表空间大小(M)”,
D.TOT_GROOTTE_MB - F.TOTAL_BYTES “已使用空间(M)”,
TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),’990.99’) || ‘%’ “使用比”,
F.TOTAL_BYTES “空闲空间(M)”,
F.MAX_BYTES “最大块(M)”
FROM (SELECT TABLESPACE_NAME,
ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
FROM SYS.DBA_FREE_SPACE
GROUP BY TABLESPACE_NAME) F,
(SELECT DD.TABLESPACE_NAME,
ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB
FROM SYS.DBA_DATA_FILES DD
GROUP BY DD.TABLESPACE_NAME) D
WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
ORDER BY 1;
–查询表空间的free space
select tablespace_name,
count(*) as extends,
round(sum(bytes) / 1024 / 1024, 2) as MB,
sum(blocks) as blocks
from dba_free_space
group by tablespace_name;
–查询表空间的总容量
select tablespace_name, sum(bytes) / 1024 / 1024 as MB
from dba_data_files
group by tablespace_name;
–查询表空间使用率
select total.tablespace_name,
round(total.MB, 2) as Total_MB,考试大论坛
round(total.MB - free.MB, 2) as Used_MB,
round((1 - free.MB / total.MB) * 100, 2) || ‘%’ as Used_Pct
from (select tablespace_name, sum(bytes) / 1024 / 1024 as MB
from dba_free_space
group by tablespace_name) free,
(select tablespace_name, sum(bytes) / 1024 / 1024 as MB
from dba_data_files
group by tablespace_name) total
where free.tablespace_name = total.tablespace_name;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您可以使用以下 SQL 语句来查看 Oracle 数据库中的表空间信息: ``` SELECT TABLESPACE_NAME, FILE_NAME FROM DBA_DATA_FILES; ``` 这将会显示出所有表空间的名称以及每个表空间所对应的数据文件的名称。 您也可以使用以下语句查看表空间的使用情况: ``` SELECT TABLESPACE_NAME, BYTES/1024/1024 "SIZE MB", MAXBYTES/1024/1024 "MAXSIZE MB", (MAXBYTES - BYTES)/1024/1024 "FREESPACE MB" FROM DBA_DATA_FILES; ``` 这将会显示出每个表空间的大小、最大大小以及剩余空间。 希望这些信息能帮到您。 ### 回答2: 要查看Oracle数据库的表空间,可以使用以下几种方法: 1. 使用系统管理员账号登录到Oracle数据库中。 2. 执行以下查询语句来查看所有表空间的信息: ``` SELECT tablespace_name, file_name, bytes/(1024*1024) AS size_MB, status FROM dba_data_files; ``` 上述查询语句将返回表空间的名称(tablespace_name),数据文件的名称(file_name),以兆字节为单位的大小(size_MB)以及表空间的状态(status)。 3. 可以进一步扩展以上查询,以获取更详细的表空间信息,包括空间利用率和自动扩展设置等。使用以下查询语句: ``` SELECT tablespace_name, file_name, bytes/(1024*1024) AS size_MB, (bytes - (SELECT sum(bytes) FROM dba_segments WHERE tablespace_name = dfs.tablespace_name)) / (bytes/1024) AS used_MB, ((SELECT sum(bytes) FROM dba_segments WHERE tablespace_name = dfs.tablespace_name)) / (bytes/1024) AS free_MB, autoextensible, status FROM dba_data_files dfs; ``` 此查询将返回表空间名称、数据文件名称、大小(以兆字节为单位)、已使用空间(以兆字节为单位)、剩余可用空间(以兆字节为单位)、是否可自动扩展(autoextensible)以及表空间状态(status)等信息。 通过以上方法,您可以方便地查看Oracle数据库中的表空间信息,并了解数据库的空间利用率和配置设置等信息。 ### 回答3: 要查看Oracle数据库中的表空间,可以使用以下方法: 1.使用系统提供的数据字典视图: 可以查询数据库中的表空间信息,常用的数据字典视图是DBA_TABLESPACES和DBA_DATA_FILES。例如,使用如下SQL语句可以查看所有表空间的名称和大小: SELECT tablespace_name, sum(bytes)/1024/1024 AS size_in_mb FROM dba_data_files GROUP BY tablespace_name; 2.使用Oracle Enterprise Manager: 如果安装了Oracle Enterprise Manager,可以通过它来查看表空间。在Enterprise Manager的网页界面上,可以选择“表空间”选项,然后列出当前数据库中的所有表空间,包括它们的大小、使用情况等详细信息。 3.使用SQL*Plus命令行工具: 可以使用Oracle官方提供的命令行工具SQL*Plus来查询表空间。首先,用合适的用户名和密码登录到所需的数据库实例上。然后,使用以下SQL语句查看所有表空间的名称和大小: SELECT tablespace_name, sum(bytes)/1024/1024 AS size_in_mb FROM dba_data_files GROUP BY tablespace_name; 以上是几种常用的查询Oracle表空间的方法,根据具体的需求和环境选择适合的方式即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值