Oracle-查询表空间使用率很慢

近期发现,因数据库监控指标采集比较频繁,甚至触发等待。

解决方案如下:

1、调整采集周期。现行的10S采集频率太高。

2、优化表空间查询语句。

3、考虑回收站原因:

3.1:查询回收站大小:

SYS@evansdb2> SELECT count(*) FROM dba_recyclebin;

COUNT(*)


127

SYS@evansdb2> SELECT value FROM v$parameter WHERE name = 'recyclebin';

VALUE


OFF

3.3:清空全库回收站

SYS@evansdb2> purge DBA_RECYCLEBIN;

DBA Recyclebin purged.

3.4 再次查询回收站大小:

SYS@evansdb2> SELECT count(*) FROM dba_recyclebin;

COUNT(*)


0

3.5 再次查询回收站大小:

SYS@evansdb2> SELECT count(*) FROM dba_recyclebin;

COUNT(*)


0

3.6 收集统计信息:

SYS@evansdb2> exec dbms_stats.gather_table_stats(ownname => 'SYS',tabname => 'RECYCLEBIN$', estimate_percent => 100, method_opt=> 'for all indexed columns',degree=>8);

PL/SQL procedure successfully completed.

3.7 重新查询表空间使用率

SYS@evansdb2> set linesize 200 pagesize 999 long 20000

set timi on ti on

col name format a30

col contents format a9

col extent_management format a8

col size_mb format a12

col Used_MB format a12

col free_mb format a12

col "Used%" format a8

col dt format a20

SELECT d.tablespace_name Name,

d.status,

d.contents,

d.extent_management,

d.segment_space_management,

a.file_cnt,

TO_CHAR(NVL(a.bytes/1048576, 0), '999G999G999') SIZE_MB,

TO_CHAR(DECODE(d.contents,'UNDO',NVL(u.bytes, 0)/1048576,NVL(a.bytes - NVL(f.bytes, 0), 0)/1048576),'999G999G999') Used_MB,

TO_CHAR(DECODE(d.contents,'UNDO',NVL(a.bytes - NVL(u.bytes, 0), 0)/1048576,NVL(f.bytes, 0)/1048576), '999G999G999') FREE_MB,

TO_CHAR(DECODE(d.contents,'UNDO',NVL(u.bytes/a.bytes * 100, 0),NVL((a.bytes - NVL(f.bytes, 0))/a.bytes * 100, 0)),'990D00') "Used%",

TO_CHAR(sysdate, 'yyyy-mm-dd hh24:mi:ss') dt

FROM sys.dba_tablespaces d,

(SELECT tablespace_name, SUM(bytes) bytes, COUNT(file_id) file_cnt

from dba_data_files

GROUP BY tablespace_name) a,

(select tablespace_name, sum(bytes) bytes

from dba_free_space

group by tablespace_name) f,

(SELECT tablespace_name, SUM(bytes) bytes

FROM (SELECT tablespace_name, sum(bytes) bytes, status

from dba_undo_extents

WHERE status = 'ACTIVE'

group by tablespace_name, status

UNION ALL

SELECT tablespace_name, sum(bytes) bytes, status

from dba_undo_extents

WHERE status = 'UNEXPIRED'

group by tablespace_name, status)

group by tablespace_name) u

WHERE d.tablespace_name = a.tablespace_name(+)

AND d.tablespace_name = f.tablespace_name(+)

AND d.tablespace_name = u.tablespace_name(+)

AND NOT (d.extent_management = 'LOCAL' AND d.contents = 'TEMPORARY')

UNION ALL

SELECT d.tablespace_name,

d.status,

d.contents,

d.extent_management,

d.segment_space_management,

a.file_cnt,

TO_CHAR(NVL(a.bytes/1048576, 0), '999G999G999') SIZE_MB,

TO_CHAR(NVL(t.bytes, 0)/1048576, '999G999G999') Used_MB,

TO_CHAR((NVL(a.bytes, 0)/1048576 - NVL(t.bytes, 0)/1048576),'999G999G999') FREE_MB,

TO_CHAR(NVL(t.bytes/a.bytes * 100, 0), '990D00') "Used%",

TO_CHAR(sysdate, 'yyyy-mm-dd hh24:mi:ss') dt

FROM sys.dba_tablespaces d,

(select tablespace_name, sum(bytes) bytes, count(file_id) file_cnt

from dba_temp_files

group by tablespace_name) a,

(select ss.tablespace_name,

sum((ss.used_blocks * ts.blocksize)) bytes

from gvsort_segment ss, sys.ts ts

where ss.tablespace_name = ts.name

group by ss.tablespace_name) t

WHERE d.tablespace_name = a.tablespace_name(+)

AND d.tablespace_name = t.tablespace_name(+)

AND d.extent_management = 'LOCAL'

AND d.contents = 'TEMPORARY'

ORDER BY "Used%";

相关推荐
m0_550024633 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦4 分钟前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_999918 分钟前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7651 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码1 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean1 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
小Tomkk2 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
qq_12498707532 小时前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
倒流时光三十年2 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉3 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot