达梦数据库针对慢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的执行计划缓存,生产环境请谨慎操作。

相关推荐
余衫马1 小时前
CentOS7 离线安装 Postgresql 指南
数据库·postgresql
E___V___E1 小时前
MySQL数据库入门到大蛇尚硅谷宋红康老师笔记 高级篇 part 2
数据库·笔记·mysql
m0_748254882 小时前
mysql之如何获知版本
数据库·mysql
mikey棒棒棒2 小时前
Redis——优惠券秒杀问题(分布式id、一人多单超卖、乐悲锁、CAS、分布式锁、Redisson)
数据库·redis·lua·redisson·watchdog·cas·并发锁
水手胡巴4 小时前
oracle apex post接口
数据库·oracle
史迪仔01126 小时前
【SQL】SQL多表查询
数据库·sql
Quz6 小时前
MySQL:修改数据库默认存储目录与数据迁移
数据库·mysql
Familyism6 小时前
Redis
数据库·redis·缓存
隔壁老登6 小时前
查询hive指定数据库下所有表的建表语句并生成数据字典
数据库·hive·hadoop
sekaii7 小时前
ReDistribution plan细节
linux·服务器·数据库