欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle?查看后臺正在執(zhí)行的?SQL?語句(最新推薦)

 更新時間:2025年07月16日 11:43:59   作者:愿與貍花過一生  
本文給大家介紹了Oracle中查看后臺SQL的多種方法,包括查詢動態(tài)性能視圖(如v$session、v$sqlarea)、使用監(jiān)控工具(如OEM)及ASH,通過SQL_ID、執(zhí)行計劃和資源消耗等字段分析SQL性能與執(zhí)行狀態(tài),感興趣的朋友一起看看吧

在 Oracle 數(shù)據(jù)庫中,要查看后臺正在執(zhí)行的 SQL 語句,可以通過查詢動態(tài)性能視圖(Dynamic Performance Views)或使用監(jiān)控工具來實現(xiàn)。

1. 查詢動態(tài)性能視圖

(1) 查看當前活躍會話及其執(zhí)行的 SQL

使用 v$session 和 v$sql 視圖關聯(lián)查詢,獲取正在執(zhí)行的 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:當前正在執(zhí)行的 SQL 語句的唯一標識。

    • sql_text:SQL 文本內(nèi)容(可能被截斷,完整內(nèi)容需從 v$sqlarea 獲取)。

    • username:執(zhí)行 SQL 的數(shù)據(jù)庫用戶。

    • program:發(fā)起 SQL 的客戶端程序(如 JDBC、SQL Developer 等)。

(2) 查看長時間運行的 SQL 操作

使用 v$session_longops 監(jiān)控長時間運行的操作(如全表掃描、索引重建等)

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: 正在執(zhí)行的操作名稱。
  • TARGET: 操作目標對象名(如果適用)。
  • TARGET_DESC: 目標描述。
  • SOFAR: 到目前為止已完成的工作量。
  • TOTALWORK: 預估的總工作量。
  • UNITS: 工作量單位。
  • START_TIME: 操作開始的時間。
  • LAST_UPDATE_TIME: 上次更新此記錄的時間。
  • TIME_REMAINING: 根據(jù)當前速度預估剩余時間(秒)。
  • ELAPSED_SECONDS: 自操作開始以來已經(jīng)過去的秒數(shù)。
  • CONTEXT: 內(nèi)部使用的上下文信息。
  • MESSAGE: 描述操作狀態(tài)的消息。
  • USERNAME: 執(zhí)行該操作的用戶名。
  • SQL_ADDRESS: SQL 語句地址。
  • SQL_HASH_VALUE: SQL 語句的哈希值。
  • SQL_ID: SQL 語句的 ID。
  • SQL_PLAN_HASH_VALUE: SQL 計劃的哈希值。
  • QCINST_ID: 并行查詢協(xié)調(diào)器實例 ID(如果是并行操作)。
  • QCSID: 并行查詢協(xié)調(diào)器的 SID(如果是并行操作)。
  • QCSERIAL#: 并行查詢協(xié)調(diào)器的 SERIAL#(如果是并行操作)。

2. 查詢 SQL 執(zhí)行詳細信息

(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語句在數(shù)據(jù)庫中的唯一標識符。這個ID可以幫助你識別和追蹤特定的SQL語句。
  • sql_text: 這是完整的SQL語句文本。它顯示了實際被執(zhí)行的SQL語句內(nèi)容。
  • executions: 表示這條SQL語句已經(jīng)被執(zhí)行了多少次。每次執(zhí)行都會增加這個計數(shù)器。
  • elapsed_time / 1000000 AS elapsed_secelapsed_time 字段表示SQL語句執(zhí)行所花費的總時間(微秒),通過除以1,000,000轉換為秒,并將其重命名為 elapsed_sec 以便更直觀地理解時間單位。
  • cpu_time / 1000000 AS cpu_seccpu_time 字段表示SQL語句執(zhí)行期間消耗的CPU時間(微秒),同樣通過除以1,000,000轉換為秒,并將其重命名為 cpu_sec。
  • disk_reads: 這個字段表示SQL語句執(zhí)行過程中發(fā)生的物理讀取次數(shù),即從磁盤讀取數(shù)據(jù)的次數(shù)。較高的值可能指示性能瓶頸。
  • buffer_gets: 表示邏輯讀的數(shù)量,即SQL語句執(zhí)行過程中從數(shù)據(jù)庫緩沖區(qū)緩存中獲取的數(shù)據(jù)塊數(shù)量。高數(shù)值可能表明該語句對系統(tǒng)資源有較高需求。

(2) 查看 SQL 執(zhí)行計劃

通過 v$sql_plan 分析 SQL 的執(zhí)行計劃:

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

 3. 使用 Oracle Enterprise Manager (OEM)

Oracle 提供的圖形化工具 Enterprise Manager (OEM) 可以直觀監(jiān)控 SQL 執(zhí)行:

  1. 登錄 OEM 控制臺。

  2. 導航到 Performance > SQL Monitoring。

  3. 查看實時 SQL 執(zhí)行的詳細信息,包括資源消耗、執(zhí)行計劃等。

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語句在數(shù)據(jù)庫中的唯一標識符。通過這個ID可以追蹤和分析特定的SQL語句。
  • sql_text: 這是SQL語句的實際文本內(nèi)容,顯示了被執(zhí)行的SQL語句的具體內(nèi)容。
  • executions: 表示這條SQL語句已經(jīng)被執(zhí)行了多少次。每次執(zhí)行都會增加這個計數(shù)器,可以幫助你了解該語句的使用頻率。
  • cpu_time / 1000000 AS cpu_seccpu_time 字段表示SQL語句執(zhí)行期間消耗的CPU時間(微秒)。通過除以1,000,000將時間單位轉換為秒,并將其重命名為 cpu_sec 以便更直觀地理解時間單位。這有助于評估SQL語句對CPU資源的占用情況。
  • elapsed_time / 1000000 AS elapsed_secelapsed_time 字段表示SQL語句執(zhí)行所花費的總時間(微秒),通過除以1,000,000轉換為秒,并將其重命名為 elapsed_sec。它包括等待時間和執(zhí)行時間,可用于評估SQL語句的整體執(zhí)行效率。

到此這篇關于Oracle 查看后臺正在執(zhí)行的 SQL 語句的文章就介紹到這了,更多相關oracle查詢正在執(zhí)行的sql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論