Oracle 性能排查:通过 V$LONG_EXEC_SQLS 快速定位慢 SQL

在 Oracle 数据库日常运维中,慢 SQL 往往是导致系统卡顿、CPU 飙高、业务响应缓慢的重要原因。

如果想快速查看当前数据库中的长时间执行 SQL,可以使用 V$LONG_EXEC_SQLS 视图。


一、查看慢 SQL 的常用语句

复制代码
select * 
from V$LONG_EXEC_SQLS
where 1=1
order by finish_time desc;

二、SQL 作用说明

该语句主要用于:

  • 查询数据库中执行时间较长的 SQL

  • 按完成时间倒序排列

  • 优先查看最近出现的慢 SQL

其中:

字段 说明
SQL_ID SQL唯一标识
EXEC_TIME 执行耗时
START_TIME 开始时间
FINISH_TIME 结束时间
SQL_TEXT SQL文本
USERNAME 执行用户

三、为什么这个视图重要?

很多 DBA 在排查性能问题时,第一反应是:

  • AWR

  • ASH

  • Top SQL

  • Explain Plan

但实际上:

V$LONG_EXEC_SQLS 更适合快速定位"当前正在拖慢系统"的 SQL。

尤其适用于:

  • 系统突然变慢

  • CPU 飙高

  • 会话阻塞

  • 批量任务执行异常

  • 夜间定时任务卡死


四、推荐优化版查询

实际生产环境中,建议不要直接 select *,可以筛选关键字段:

复制代码
select 
    sql_id,
    username,
    exec_time,
    start_time,
    finish_time,
    substr(sql_text,1,100) sql_text
from V$LONG_EXEC_SQLS
order by exec_time desc;

这样可以:

  • 提高查询效率

  • 避免输出过长

  • 更容易快速分析


五、发现慢 SQL 后怎么办?

拿到 SQL 后,建议继续执行:

1. 查看执行计划

复制代码
explain plan for SQL语句;

2. 查看是否走索引

重点关注:

  • FULL TABLE SCAN

  • HASH JOIN

  • SORT

  • TEMP

3. 检查是否存在:

  • 大表全扫描

  • 缺失索引

  • 隐式类型转换

  • 返回数据过多

  • where 条件未命中索引


六、实际生产经验

在生产环境中,经常遇到:

  • 一个没有索引的查询

  • 导致几十亿数据扫描

  • CPU 直接打满

  • 整个数据库响应变慢

而通过:

复制代码
V$LONG_EXEC_SQLS

往往几分钟内就能定位问题 SQL。


七、总结

V$LONG_EXEC_SQLS 是 Oracle DBA 排查性能问题非常实用的视图。

建议:

  • 日常巡检定期查看

  • 配合 AWR/ASH 使用

  • 建立慢 SQL 监控机制

一句话:

数据库性能问题,80% 都能从慢 SQL 入手解决。

相关推荐
初圣魔门首席弟子1 小时前
Qt C++ 项目实战:修改共享头文件后的高效增量编译与快速发布流程
数据库
wb043072011 小时前
仓库搬家不停业——从阿明的“在线换仓库“,看数据库迁移与 Schema 演进的实战方法论
数据库·adb·架构
lx188548698961 小时前
Redis大Key阻塞:单线程CPU100%的致命陷阱
数据库·redis·缓存
IT策士1 小时前
Redis 从入门到精通:位图、HyperLogLog、GEO
数据库·redis·缓存
IT策士1 小时前
Redis 从入门到精通:Python 操作 Redis 进阶
数据库·redis·python
IvorySQL1 小时前
PostgreSQL 技术日报 (6月8日)|索引预取迭代,AI 安全功能上新
数据库·人工智能·sql·安全·postgresql
阿正的梦工坊2 小时前
【Rust】05-结构体、枚举与模式匹配
java·数据库·rust
cjp5602 小时前
006.WEB_API使用本地数据库 SQLite + Dapper 入门教程
数据库·sqlite
新新学长搞科研2 小时前
【广东省博促会主办】2026年第七届先进材料与智能制造国际学术会议(ICAMIM 2026)
大数据·前端·数据库·人工智能·物联网
睡不醒男孩0308232 小时前
CLup篇之PostgreSQL管理
数据库·postgresql