ORACLE CPU过高的sql查询
1、 根据占用CPU高的进程号来查询这个进程执行的SQL语句:
CPU过高的进程号:
#首先找到CPU过高的进程号
# top -bn1 是静态找到占用最高的进程
[root@localhost ~]# top -bn1 | awk
'{print $1}'
| grep -A2 PID
命令详解:
top:top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况
-bn1: 显示所有的进程信息 (top -bn 1 显示所有进程信息,top -n 1 只显示一屏信息,供管道调用 )
awk
'{print $1}':
awk是用来提取列的主要工具;
{print $1}就是将某一行(一条记录)中以空格为分割符的第一个字段打印出来
grep -A2 PID : (查看前二行的进程号) -A: 显示匹配行及前面多少行, 如: -A3, 则表示显示匹配行及前3行
SQL语句:
SELECT
sql_text
FROM
V$sqltext a
WHERE
(a.hash_value, a.address)
IN
(
SELECT
DECODE(sql_hash_value, 0 , prev_hash_value, sql_hash_value),
DECODE(sql_hash_value, 0 ,prev_sql_addr, sql_address)
FROM
v$session b
WHERE
b.paddr = (
SELECT
addr
FROM
v$process c
WHERE
c.spid =
'&pid'
))
ORDER
BY
piece
ASC
;
#######
ex:
SELECT
sql_text
FROM
v$sqltext a
WHERE
(a.hash_value, a.address)
IN
(
SELECT
DECODE(sql_hash_value, 0, prev_hash_value, sql_hash_value),
DECODE(sql_hash_value, 0, prev_sql_addr, sql_address)
FROM
v$session b
WHERE
b.paddr = (
SELECT
addr
FROM
v$process c
WHERE
c.spid =
'3515'
))
ORDER
BY
piece
ASC
;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了