MYSQL|ORACLE表空间查询SQL

对于工作中,多数环境可以对数据库进行增改,但是个别环境增改存在插入异常,可以考虑表空间是否使用率达到了100%

查看数据库所有表空间

sql 复制代码
select tablespace_name, sum(bytes)/1024/1024 from dba_data_files group by tablespace_name;

查看具体表单所占空间

sql 复制代码
Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name

查看所有表空间占用率

sql 复制代码
SELECT --B.file_name "文件名",
       A.TABLESPACE_NAME "表空间名",
       TOTAL "表空间大小",
       FREE "表空间剩余大小",
       (TOTAL - FREE) "表空间使用大小",
       TOTAL / (1024 * 1024 * 1024) "表空间大小(G)",
       FREE / (1024 * 1024 * 1024) "表空间剩余大小(G)",
       (TOTAL - FREE) / (1024 * 1024 * 1024) "表空间使用大小(G)",
       ROUND((TOTAL - FREE) / TOTAL, 4) * 100 "使用率 %"
FROM   (SELECT TABLESPACE_NAME,
               SUM(BYTES) FREE
        FROM   DBA_FREE_SPACE
        GROUP  BY TABLESPACE_NAME) A,
       (SELECT TABLESPACE_NAME,
             --  file_name,
               SUM(BYTES) TOTAL
        FROM   DBA_DATA_FILES
        GROUP  BY TABLESPACE_NAME/*,file_name*/) B
WHERE  A.TABLESPACE_NAME = B.TABLESPACE_NAME;

查看具体dbf表空间占用率

sql 复制代码
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

sqlserver可以不用考虑表空间的问题

相关推荐
q***448121 分钟前
PostgreSQL的备份方式
数据库·postgresql
v***598322 分钟前
【SQL Server】超详细SQLServer日期转换、字符串、数学、聚合等常用函数大全(最新版)
数据库·sqlserver
q***235726 分钟前
python的sql解析库-sqlparse
数据库·python·sql
云和数据.ChenGuang35 分钟前
运维面试题之oracle和mysql单表最大容量
运维·mysql·oracle
q***925140 分钟前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
gladiator+42 分钟前
Redis之BigKey的常见问题以及大厂相关面试题
java·数据库·redis
合方圆~小文1 小时前
AI摄像头精准识别技术依赖于深度算法
数据结构·数据库·数码相机·模块测试
tanxiaomi1 小时前
Redis相关面试题
数据库·redis·缓存
钮钴禄·爱因斯晨1 小时前
【探索实战】KuratorGitOps 多环境配置管理与合规审计
数据库
Z***G4792 小时前
【零基础学Mysql】常用函数讲解,提升数据操作效率的利器
数据库·mysql