当前位置: 首页 > article >正文

Oracle 查看后台正在执行的 SQL 语句

在 Oracle 数据库中,要查看后台正在执行的 SQL 语句,可以通过查询动态性能视图(Dynamic Performance Views)或使用监控工具来实现。

1. 查询动态性能视图

(1) 查看当前活跃会话及其执行的 SQL

使用 v$session 和 v$sql 视图关联查询,获取正在执行的 SQL 信息:

SELECT s.sid, s.serial#,s.username, s.status,s.sql_id, s.prev_sql_id,q.sql_text,s.program,s.machine,s.logon_time
FROM v$session s
LEFT JOIN v$sql q ON s.sql_id = q.sql_id
WHERE s.status = 'ACTIVE'   -- 筛选活跃会话AND s.type != 'BACKGROUND'  -- 排除后台进程AND s.sql_id IS NOT NULL;

 

  • 关键字段

    • sql_id:当前正在执行的 SQL 语句的唯一标识。

    • sql_text:SQL 文本内容(可能被截断,完整内容需从 v$sqlarea 获取)。

    • username:执行 SQL 的数据库用户。

    • program:发起 SQL 的客户端程序(如 JDBC、SQL Developer 等)。

(2) 查看长时间运行的 SQL 操作

使用 v$session_longops 监控长时间运行的操作(如全表扫描、索引重建等)

SELECT sid, serial#,opname, target,sofar, totalwork,ROUND(sofar / totalwork * 100, 2) AS progress_pct,elapsed_seconds,time_remaining
FROM v$session_longops
WHERE time_remaining > 0;  -- 仅显示未完成的操作

 

  • SID: 会话标识符。
  • SERIAL#: 会话序列号,与 SID 一起用于唯一标识一个会话。
  • OPNAME: 正在执行的操作名称。
  • TARGET: 操作目标对象名(如果适用)。
  • TARGET_DESC: 目标描述。
  • SOFAR: 到目前为止已完成的工作量。
  • TOTALWORK: 预估的总工作量。
  • UNITS: 工作量单位。
  • START_TIME: 操作开始的时间。
  • LAST_UPDATE_TIME: 上次更新此记录的时间。
  • TIME_REMAINING: 根据当前速度预估剩余时间(秒)。
  • ELAPSED_SECONDS: 自操作开始以来已经过去的秒数。
  • CONTEXT: 内部使用的上下文信息。
  • MESSAGE: 描述操作状态的消息。
  • USERNAME: 执行该操作的用户名。
  • SQL_ADDRESS: SQL 语句地址。
  • SQL_HASH_VALUE: SQL 语句的哈希值。
  • SQL_ID: SQL 语句的 ID。
  • SQL_PLAN_HASH_VALUE: SQL 计划的哈希值。
  • QCINST_ID: 并行查询协调器实例 ID(如果是并行操作)。
  • QCSID: 并行查询协调器的 SID(如果是并行操作)。
  • QCSERIAL#: 并行查询协调器的 SERIAL#(如果是并行操作)。

2. 查询 SQL 执行详细信息

(1) 通过 v$sqlarea 查看完整的 SQL 文本

SELECT sql_id, sql_text,executions,elapsed_time / 1000000 AS elapsed_sec,cpu_time / 1000000 AS cpu_sec,disk_reads,buffer_gets
FROM v$sqlarea
WHERE sql_id = '<your_sql_id>';  -- 替换为实际的 sql_id
  • sql_id: 每条SQL语句在数据库中的唯一标识符。这个ID可以帮助你识别和追踪特定的SQL语句。
  • sql_text: 这是完整的SQL语句文本。它显示了实际被执行的SQL语句内容。
  • executions: 表示这条SQL语句已经被执行了多少次。每次执行都会增加这个计数器。
  • elapsed_time / 1000000 AS elapsed_secelapsed_time 字段表示SQL语句执行所花费的总时间(微秒),通过除以1,000,000转换为秒,并将其重命名为 elapsed_sec 以便更直观地理解时间单位。
  • cpu_time / 1000000 AS cpu_seccpu_time 字段表示SQL语句执行期间消耗的CPU时间(微秒),同样通过除以1,000,000转换为秒,并将其重命名为 cpu_sec
  • disk_reads: 这个字段表示SQL语句执行过程中发生的物理读取次数,即从磁盘读取数据的次数。较高的值可能指示性能瓶颈。
  • buffer_gets: 表示逻辑读的数量,即SQL语句执行过程中从数据库缓冲区缓存中获取的数据块数量。高数值可能表明该语句对系统资源有较高需求。

(2) 查看 SQL 执行计划

通过 v$sql_plan 分析 SQL 的执行计划:

SELECT * 
FROM v$sql_plan 
WHERE sql_id = '<your_sql_id>';

 3. 使用 Oracle Enterprise Manager (OEM)

Oracle 提供的图形化工具 Enterprise Manager (OEM) 可以直观监控 SQL 执行:

  1. 登录 OEM 控制台。

  2. 导航到 Performance > SQL Monitoring

  3. 查看实时 SQL 执行的详细信息,包括资源消耗、执行计划等。

4. 使用 Active Session History (ASH)

通过 v$active_session_history 查询历史活动会话信息(采样频率为每秒一次):

 

SELECT sql_id,session_id,session_serial#,sample_time,event,wait_time
FROM v$active_session_history
WHERE sql_id IS NOT NULL
ORDER BY sample_time DESC;

快速定位问题 SQL

-- 查看消耗最多 CPU 的 SQL
SELECT sql_id,sql_text,executions,cpu_time / 1000000 AS cpu_sec,elapsed_time / 1000000 AS elapsed_sec
FROM v$sqlarea
ORDER BY cpu_time DESC
FETCH FIRST 10 ROWS ONLY;
  • sql_id: 每条SQL语句在数据库中的唯一标识符。通过这个ID可以追踪和分析特定的SQL语句。
  • sql_text: 这是SQL语句的实际文本内容,显示了被执行的SQL语句的具体内容。
  • executions: 表示这条SQL语句已经被执行了多少次。每次执行都会增加这个计数器,可以帮助你了解该语句的使用频率。
  • cpu_time / 1000000 AS cpu_seccpu_time 字段表示SQL语句执行期间消耗的CPU时间(微秒)。通过除以1,000,000将时间单位转换为秒,并将其重命名为 cpu_sec 以便更直观地理解时间单位。这有助于评估SQL语句对CPU资源的占用情况。
  • elapsed_time / 1000000 AS elapsed_secelapsed_time 字段表示SQL语句执行所花费的总时间(微秒),通过除以1,000,000转换为秒,并将其重命名为 elapsed_sec。它包括等待时间和执行时间,可用于评估SQL语句的整体执行效率。

相关文章:

Oracle 查看后台正在执行的 SQL 语句

在 Oracle 数据库中&#xff0c;要查看后台正在执行的 SQL 语句&#xff0c;可以通过查询动态性能视图&#xff08;Dynamic Performance Views&#xff09;或使用监控工具来实现。 1. 查询动态性能视图 (1) 查看当前活跃会话及其执行的 SQL 使用 v$session 和 v$sql 视图关联…...

SpringBoot整合MinIO快速入门:实现分布式文件存储与管理

文章目录 一、MinIO是什么&#xff1f;为什么选择它&#xff1f;1.1 什么是MinIO&#xff1f;1.2 核心优势 二、本地快速搭建MinIO服务2.1 Docker一键部署2.2 访问管理界面2.3 创建存储桶&#xff08;Bucket&#xff09; 三、SpringBoot集成MinIO客户端3.1 添加Maven依赖3.2 配…...

我的NISP二级之路-03

目录 一.ISMS 二.IP 三.http 四.防火墙 五.文件 解析 解析 六.攻击 解析 解析 七.风险管理工程 八.信息系统安全保护等级 九.我国信息安全保障 一.ISMS 1.文档体系建设是信息安全管理体系(ISMS)建设的直接体现&#xff0c;下列说法不正确的是&#xff1a; A&#…...

Vue框架的Diff算法

以下是关于 Diff 算法 的系统梳理: 一、Diff 算法的核心目标 最小化 DOM 操作:通过虚拟 DOM 对比,找出真实 DOM 的最小变更集高效节点复用:尽可能复用相同节点,减少创建/销毁开销顺序优化处理:优先处理高频变更场景(如列表尾部追加)保证渲染正确性:正确处理组件状态和…...

Oracle 表空间高水位收缩全攻略

1. 概述 本文档是针对某个特定用户表空间收缩的文档&#xff0c;实际操作要结合生产库具体情况。主要包括以下几个流程&#xff1a; 收集当前数据库相关信息降低数据库表高水位线Resize 收缩数据文件 具体细节详见以下章节。 2. 时间规划 操作类型预估时间实际时间数据库信…...

ESModule和CommonJS在Node中的区别

ESModule console.log(require);//>errorconsole.log(module);//>errorconsole.log(exports);//>errorconsole.log(__filename);//>errorconsole.log(__dirname);//>error全部报错commonjs console.log(require);console.log(module);console.log(exports);co…...

floyd模板

B3647 【模板】Floyd - 洛谷 f l o y d floyd floyd 模板 对于 f l o y d floyd floyd 算法来说时间复杂度为 O ( n 3 ) O(n^3) O(n3) &#xff0c;不如跑 n n n 遍 h e a p _ d i j k s t r a heap\_dijkstra heap_dijkstra 算法 题目大意&#xff1a; 给出一张由 n n …...

力扣刷题-热题100题-第34题(c++、python)

23. 合并 K 个升序链表 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/merge-k-sorted-lists/?envTypestudy-plan-v2&envIdtop-100-liked 顺序合并 合并两个有序链表作为子函数&#xff0c;创建一个空链表&#xff0c;然后对含有多个链表的数组进…...

括号匹配问题--栈

括号匹配问题 栈的应用代码概览栈操作函数详解1.初始化栈&#xff08;stackInit&#xff09;2.向栈中压入元素&#xff08;stackpush&#xff09;3.获取栈顶元素&#xff08;stacktop&#xff09;4.弹出栈顶元素&#xff08;stackpop&#xff09;5.销毁栈&#xff08;stackdest…...

原生SSE实现AI智能问答+Vue3前端打字机流效果

实现流程&#xff1a; 1.用户点击按钮从右侧展开抽屉&#xff08;drawer&#xff09;&#xff0c;打开模拟对话框 2.用户输入问题&#xff0c;点击提问按钮&#xff0c;创建一个SSE实例请求后端数据&#xff0c;由于SSE是单向流&#xff0c;所以每提一个问题都需要先把之前的实…...

LLC工作模态详解

1以半桥LLC谐振变换器为例&#xff0c;主开关Q1、Q2构成半桥结构&#xff0c;其驱动信号为固定占空比50%的互补信号&#xff0c;并且在上下桥臂之间应有死区时间。 谐振电感Ls、谐振电感Cs和变压器励磁电感Lm共同构成谐振槽路&#xff0c;具有两个谐振频率&#xff1a; 谐振电…...

线代第三课:n阶行列式

引言 行标取自然排列 不同行不同列的3个元素相乘 列标取排列的所有可能 列标排列的逆序数的奇偶性决定符号&#xff0c;- n阶行列式 第一种&#xff1a;按行展开 (1) 行标取自然排列 (2) 列标取排列的所有可能 &#xff08;PS&#xff1a;可以理解为随意取&#xff09; (3) 从…...

机器学习的一百个概念(10)假阳性率

前言 本文隶属于专栏《机器学习的一百个概念》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见[《机器学习的一百个概念》 ima 知识库 知识库广场搜索: 知识库创建人机器学习@Shockang机器学习数学基础@Shocka…...

GitHub 克隆/下载失败的解决方案

&#x1f680; GitHub 下载/克隆失败&#xff1f;一招搞定代理配置与回滚&#xff01; 在国内使用 Git 操作 GitHub 时&#xff0c;经常会遇到以下问题&#xff1a; ❌ 下载失败、超时 ❌ Failed to connect to github.com port 443 ❌ SSL certificate problem 本文将详细讲解…...

pulsar proxy详解

什么是 Pulsar Proxy&#xff1f; Pulsar Proxy 是 Apache Pulsar 中的一个可选组件&#xff0c;作用是作为客户端与 Pulsar Brokers 之间的中间网关层。它并不是 Pulsar 核心功能必须的部分&#xff0c;但在特定场景下&#xff08;如复杂的网络环境、安全性需求或动态集群管理…...

C++ Socket优化实战:提升网络应用的性能与效率

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家、CSDN平台优质创作者&#xff0c;高级开发工程师&#xff0c;数学专业&#xff0c;拥有高级工程师证书&#xff1b;擅长C/C、C#等开发语言&#xff0c;熟悉Java常用开发技术&#xff0c;能熟练应用常用数据库SQL server,Oracle…...

STM32单片机入门学习——第30节: [9-6] FlyMcu串口下载STLINK Utility

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难&#xff0c;但我还是想去做&#xff01; 本文写于&#xff1a;2025.04.09 STM32开发板学习——第30节: [9-6] FlyMcu串口下载&STLINK Utility 前言开发…...

Qt容器类在元对象系统中使用

解释 “QVector没有被注册到Qt的元对象系统中”这句话的意思是&#xff1a;QVector<double>这种数据类型没有被Qt的元对象系统&#xff08;Meta-Object System&#xff09;识别和管理。Qt的元对象系统是Qt框架的核心部分&#xff0c;它提供了信号与槽机制、动态属性系统…...

亮相CMEF,美的医疗全维度打造智慧医疗新生态

当下&#xff0c;医疗科技革命的浪潮正汹涌而来&#xff0c;AI技术在中国医疗器械领域迅猛发展&#xff0c;释放出巨大的潜力。 4月8日&#xff0c;在第91届中国国际医疗器械博览会&#xff08;CMEF&#xff09;上&#xff0c;2025美的医疗年度新品发布暨中国脊梁守护计划启动…...

数据库视图讲解(view)

一、为什么需要视图 二、视图的讲解 三、总结 一、为什么需要视图 视图一方面可以帮我们使用表的一部分而不是所有的表&#xff0c;另一方面也可以针对不同的用户制定不同的查询视图。 比如&#xff0c;针对一个公司的销售人员&#xff0c;我们只想给他看部分数据&#xff0c…...

TQTT_KU5P开发板教程---文件的烧写与程序固化

文档功能介绍 本文档所描述的为文件的烧写固化&#xff0c;利用spi芯片将程序固化带芯片上&#xff0c;可以让开发板在重新上电时也可以跑程序。我们所使用的芯片型号为mt25qu256-spi-x1_x2_x4.本次实验采用的在led_shift项目的基础上将流水灯程序固化到flash芯片上&#xff0c…...

进度管理__制订进度计划_资源平衡和资源平滑

本文讲解的资源平衡与资源平滑&#xff0c;是制订进度计划的工具与技术的第3项&#xff1a; 资源优化。 1. 资源平衡 资源平衡是为了在资源需求与资源供给之间取得平等&#xff0c; 根据资源制约因素对开始日期和完成日期进行调整的一种技术。 如果共享资源或关键资源只在特定…...

【ISP】ISP pipeline(AI)

ISP Pipeline 全流程概览 ISP&#xff08;Image Signal Processing&#xff0c;图像信号处理&#xff09;流程通常从原始 Bayer 数据出发&#xff0c;经过一系列模块处理&#xff0c;逐步完成图像校正和增强&#xff0c;最终生成用于显示或编码的标准图像。常见处理模块包括&a…...

C++ RAII 的用途及业务代码实现案例

C RAII 的用途及业务代码实现案例 RAII 的核心概念 RAII (Resource Acquisition Is Initialization&#xff0c;资源获取即初始化) 是 C 的核心编程范式&#xff0c;其核心思想是&#xff1a; 资源获取与对象构造绑定资源释放与对象析构绑定利用 C 对象生命周期自动管理资源…...

RVOS-2.基于NS16550a ,为os添加终端交互功能。

2.1 实验目的 为os添加uart功能&#xff0c;通过串口实现开发板与PC交互。 2.1 硬件信息 QEMU虚拟SoC含有 虚拟NS16550A设备 。 不同的地址线组合&#xff08;A2、A1、A0&#xff09;对应的读写模式和寄存器如下所示&#xff1a; 2.2 NS16550a 的初始化 线路控制寄存器&#…...

#SVA语法滴水穿石# (004)关于 ended 和 triggered 用法

在 SystemVerilog 断言(SVA, SystemVerilog Assertions)中,ended 是一个用于 序列(sequence) 的关键字,它表示某个序列(sequence)在特定时间点已经成功匹配(即“结束”)。 ended 主要用于 同步不同序列的时间关系,尤其是在多序列组合或属性(property)中需要对齐时…...

软件学报 区块链论文 截止2025年4月 录用汇总 附pdf下载

截止 2025年4月 软件学报 2024年 区块链论文 录用汇总 附pdf下载 1 Title: 基于多父链辅助工作量证明共识机制的后量子区块链系统 Authors: Key words: 区块链;后量子密码;共识机制;辅助工作量证明 Abstract: 随着量子计算机的发展,对于以传统椭圆曲线数字签名为基石的公…...

损失函数篇——针对YOLO-MIFIN模型

1. 总损失函数&#xff08;公式9&#xff09; L all λ conf L conf λ cls L cls λ loc L loc (9) L_{\text{all}} \lambda_{\text{conf}} L_{\text{conf}} \lambda_{\text{cls}} L_{\text{cls}} \lambda_{\text{loc}} L_{\text{loc}} \tag{9} Lall​λconf​Lconf​λ…...

【MySQL 数据库】增删查改操作CRUD(上)

&#x1f525;博客主页&#x1f525;&#xff1a;【 坊钰_CSDN博客 】 欢迎各位点赞&#x1f44d;评论✍收藏⭐ 目录 1. CRUD 简介 2. Create -- 新增 2.1 语法 2.2 练习 3. Retrieve -- 检索 3.1 Select -- 查询 3.1.1 全列查询 3.1.2 指定列查询 3.1.3 表达式查询 3.…...

pycharm 有智能提示,但是没法自动导包,也就是alt+enter无效果

找到file->settings->editor->inspections 把python勾选上&#xff0c;原来不能用是因为只勾选了一部分。...