达梦数据库针对慢SQL,收集统计信息&清除执行计划缓存

前言:若遇到以下场景,大概率是SQL走错了执行计划:

1、一条SQL在页面上查询特别慢,但拿到数据库终端执行特别快

2、一条SQL在某种检索条件下查询特别慢,但拿到数据库终端执行特别快

此时,可以尝试按照下述步骤进行恢复:

目录

一、分析SQL语句中涉及到的物理表,依次收集统计信息

1、单表数据量小的表,可通过以下方式收集(针对表中所有字段收集,速度相对慢)

2、单表数据量大的表,可通过以下方式收集(针对表中单个字段收集,速度相对快)

二、SQL语句涉及表的统计信息收集完毕后,清除当前SQL的执行计划缓存

1、查询指定SQL的所有执行计划缓存(一条SQL可能会有多条执行计划缓存,每个缓存都有一个唯一的cache_item值,逐一记录每个cache_item值)

2、根据第一步得到的所有cache_item,清除当前SQL所有的执行计划缓存


一、分析SQL语句中涉及到的物理表,依次收集统计信息
1、单表数据量小的表,可通过以下方式收集(针对表中所有字段收集,速度相对慢)
sql 复制代码
-- 指定表收集全表字段统计信息
call DBMS_STATS.GATHER_TABLE_STATS('模式名', '物理表名称', NULL, 100, TRUE, 'FOR ALL COLUMNS SIZE AUTO', 64,'GLOBAL');

--示例:
call DBMS_STATS.GATHER_TABLE_STATS('SYSTEM', 'ORDER_TEST', NULL, 100, TRUE, 'FOR ALL COLUMNS SIZE AUTO', 64,'GLOBAL');
2、单表数据量大的表,可通过以下方式收集(针对表中单个字段收集,速度相对快)
sql 复制代码
-- 指定字段收集统计信息
stat 100 on 物理表名(表字段名);

--示例:
stat 100 on ORDER_TEST(ID);
stat 100 on ORDER_TEST(AMOUNT);
stat 100 on ORDER_TEST(DELETE_FLAG);
stat 100 on ORDER_TEST(ACCOUNTING_MONTH);
二、SQL语句涉及表的统计信息收集完毕后,清除当前SQL的执行计划缓存
1、查询指定SQL的所有执行计划缓存(一条SQL可能会有多条执行计划缓存,每个缓存都有一个唯一的cache_item值,逐一记录每个cache_item值)
sql 复制代码
-- 模糊查询指定SQL的所有执行计划缓存,获取SQL对应的cache_item字段值
select cache_item, *
from v$cachepln
where sqlstr like '%你的SQL语句%';

--示例:
select cache_item, *
from v$cachepln
where sqlstr like '%SELECT * FROM ORDER_TEST WHERE ACCOUNTING_MONTH = '2025-01'%';
2、根据第一步得到的所有cache_item,清除当前SQL所有的执行计划缓存
sql 复制代码
-- 指定清空某条SQL的缓存(cache_item字段来源于 第一步)
call SP_CLEAR_PLAN_CACHE(cache_item);

示例:
call SP_CLEAR_PLAN_CACHE(281008439485408);

特别注意:SP_CLEAR_PLAN_CACHE存储过程执行时,若不传cache_item,则会清除当前模式下所有SQL的执行计划缓存,生产环境请谨慎操作。

相关推荐
睡不醒男孩03082318 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐21 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪21 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通21 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..1 天前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29141 天前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜1 天前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊1 天前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅1 天前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 20231 天前
Vue复习
linux·服务器·数据库