Oracle 如何停止正在運行的 Job

Oracle 如何停止正在運行的 Job

先了解是dbms_job 還是 dbms_scheduler,再確定操作命令。

一 使用 DBMS_JOB 包停止作業(適用于舊版 Job)

1.1 查看正在運行的 Job

SELECT job, what, this_date, this_sec, failures, broken 
FROM user_jobs 
WHERE running = 1;

1.2 停止正在運行的 Job

-- 方法1:將作業標記為 broken 狀態
BEGINDBMS_JOB.BROKEN(job_id, TRUE);COMMIT;
END;
/-- 方法2:直接刪除作業
BEGINDBMS_JOB.REMOVE(job_id);COMMIT;
END;
/

二 使用 DBMS_SCHEDULER 包停止作業(推薦用于新版 Scheduler Job)

2.1 查看正在運行的 Scheduler Job

SELECT job_name, status, elapsed_time 
FROM user_scheduler_running_jobs;

2.2 停止正在運行的 Scheduler Job

-- 方法1:停止單個作業
BEGINDBMS_SCHEDULER.STOP_JOB(job_name => 'YOUR_JOB_NAME', force => TRUE);
END;
/-- 方法2:停止所有運行中的作業(謹慎使用)
BEGINFOR r IN (SELECT job_name FROM user_scheduler_running_jobs) LOOPDBMS_SCHEDULER.STOP_JOB(r.job_name, force => TRUE);END LOOP;
END;
/

三 通過會話級別終止 Job

3.1 查找 Job 對應的會話

SELECT s.sid, s.serial#, s.username, s.program, j.job, j.what
FROM v$session s, dba_jobs_running jr, dba_jobs j
WHERE s.sid = jr.sid
AND jr.job = j.job;

3.2 終止會話

ALTER SYSTEM KILL SESSION 'sid,serial#' IMMEDIATE;

四 注意事項

  1. 強制停止 vs 正常停止

    • force => FALSE(默認):等待當前操作完成
    • force => TRUE:立即中斷
  2. 狀態檢查

    -- 檢查作業狀態
    SELECT job_name, state FROM user_scheduler_jobs;-- 檢查作業運行歷史
    SELECT * FROM user_scheduler_job_run_details 
    ORDER BY log_date DESC;
    
  3. 自動重試:停止作業不會自動禁用,如需永久禁用:

    BEGINDBMS_SCHEDULER.DISABLE('YOUR_JOB_NAME');
    END;
    /
    
  4. 依賴關系:停止鏈式作業(chain job)時可能需要停止整個鏈

五 最佳實踐

  1. 先檢查后停止

    -- 檢查作業詳情
    SELECT job_name, enabled, state, run_count, failure_count
    FROM user_scheduler_jobs
    WHERE job_name = 'YOUR_JOB_NAME';
    
  2. 記錄操作

    -- 記錄停止作業的操作
    INSERT INTO job_control_log 
    VALUES('YOUR_JOB_NAME', 'STOPPED', SYSDATE, USER);
    COMMIT;
    
  3. 后續處理

    • 停止后可能需要手動清理殘留數據
    • 對于重要作業,停止后應考慮重新調度

更詳細的內容請查看官方文檔:

https://docs.oracle.com/en/database/oracle/oracle-database/12.2/arpls/DBMS_JOB.html#GUID-8C62D808-D7A3-4D21-B87F-A229B7CE1956

謹記:心存敬畏,行有所止。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/77456.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/77456.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/77456.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

真實波幅策略思路

該策略是一種基于ATR(Average True Range)指標的交易策略,主要用于期貨市場中的日內交易。策略的核心思想是利用ATR指標來識別市場的波動范圍,并結合均線過濾來確定買入和賣出的時機。 交易邏輯思維 1. 數據準備與初始化 - 集合競…

Web3技術如何提升用戶數據保護

在這個信息爆炸的時代,用戶數據保護已成為全球關注的焦點。Web3 技術,作為下一代互聯網的代表,以其去中心化、安全性和用戶主權等特點,為用戶數據保護提供了新的解決方案。本文將探討 Web3 技術如何提升用戶數據保護。 去中心化存…

銀河麒麟系統 達夢8 安裝 dlask 框架后端環境

適配的一套環境為 dmPython2.5.8 dmSQLAlchemy1.4.39 Flask2.0.3 Flask-Cors3.0.10 Flask-SQLAlchemy2.5.1 SQLAlchemy1.4.54 Werkzeug2.2.2其中 # sqlalchemy-dm1.4.39 通過dmdbms目錄內文件進行源碼安裝 (MindSpore) [ma-user python]$pwd /home/syl/dmdbms/drivers/python…

利用 i2c 快速從 Interface 生成 Class

利用 i2c 快速從 Interface 生成 Class(支持 TS & ArkTS) 在日常 TypeScript 或 ArkTS 開發中,需要根據 interface 定義手動實現對應的 class,這既重復又容易出錯。分享一個命令行工具 —— interface2class,簡稱…

015-C語言字符函數和字符串函數

C語言字符函數和字符串函數 文章目錄 C語言字符函數和字符串函數1. 字符分類函數2. 字符轉換函數3. strlen4. strcpy5. strcat6. strcmp7. strncpy8. strncat9. strncmp10. strstr11. strtok12. strerror 1. 字符分類函數 C語言中有一系列函數是專門做字符分類的,也…

CGAL邊折疊edge_collapse的問題

使用edge_collapse對一個模型簡化,之后回收垃圾,collect_garbage 處理之前的頂點和三角形數量: number_of_vertices: 955730 number_of_faces: 1903410 num_vertices: 955730 num_faces: 1903410 處理之后的頂點和三角形數量:…

用c語言實現——順序隊列支持用戶輸入交互、入隊、出隊、查找、遍歷、計算隊列長度等功能。確定判斷判滿的方法為:犧牲一個存儲單元方式

一、知識介紹 1.基本原理 在順序隊列中,我們使用一個固定大小的數組來存儲隊列中的元素,并使用兩個指針(front 和 rear)來分別表示隊頭和隊尾的位置。 隊列為空的條件:front rear 隊列滿的條件:rear 1…

JVM 系列:JVM 內存結構深度解析

你點贊了嗎?你關注了嗎?每天分享干貨好文。 高并發解決方案與架構設計。 海量數據存儲和性能優化。 通用框架/組件設計與封裝。 如何設計合適的技術架構? 如何成功轉型架構設計與技術管理? 在競爭激烈的大環境下&#xff0c…

手機上的APN是什么,該怎么設置

網上說改個APN就可以讓網速快幾倍,那到底APN是個什么東西,真的能讓網速快幾倍嗎? APN的作用 網絡連接基礎:APN(接入點名稱)是手機連接移動網絡的“橋梁”,負責識別運營商網絡類型(…

微服務治理與可觀測性

服務注冊與發現 核心功能 服務實例動態變化:實例可能因擴縮容、故障或遷移導致IP變動。服務依賴解耦:調用方無需硬編碼服務地址,降低耦合度。負載均衡:自動選擇健康實例,提升系統可用性。 核心組件 服務注冊中心&am…

嵌入式linux系統中內存管理的方法與實現

第一:linux內核管理詳解圖形 第二:Linux內存管理詳細分析 深入剖析Linux內核內存管理 作為嵌入式系統開發者,理解Linux內核的內存管理對于開發高效、穩定的系統至關重要。在這篇文章中,我們將詳細解析Linux內核如何劃分物理內存和虛擬內存,頁表、MMU(內存管理單元)與TL…

【dataframe顯示不全問題】打開一個行列超多的excel轉成df之后行列顯示不全

出現問題如下圖: 解決方案~ display.width解決列顯示不全 pd.set_option(display.max_columns,1000) pd.set_option(display.width, 1000) pd.set_option(display.max_colwidth,1000) pd.set_option(display.max_rows,1000)

Linux——Shell編程之正則表達式與文本處理器(筆記)

目錄 基礎正則表達式 1:基礎正則表達式示例 (4)查找任意一個字符“.”與重新字符“*” (5)查找連續字符范圍“{ }” 文本處理器 一、sed工具 二、awk工具 (1)按行輸出文本 (2&#xff0…

OpenHarmony系統-源碼下載,環境搭建,編譯,燒錄,調試

獲取源碼 以OpenHarmony5.0.3為例 repo init -u https://gitee.com/openharmony/manifest -b OpenHarmony-5.0.3-Release --no-repo-verify repo sync -c repo forall -c git lfs pull搭建環境 安裝必要的工具和命令 apt-get install -y apt-utils binutils bison flex bc …

Vue3 本地打包啟動白屏解決思路!! !

“為什么我訪問 http://127.0.0.1:5501/index.html 白屏,刪了 index.html 再訪問 / 就又活過來了?” —— 你的項目與 SPA 路由的“宮斗大戲” 一、問題復現 場景 本地通過 VSCode Live Server(或其他靜態服務器)啟動了打包后的 V…

數字人(2):數字人技術全景透視(2025演進版)

隨著人工智能技術的迅猛發展,數字人技術發展也是一日千里。站在當下,著眼未來,我們一起在回眸透視過去的基礎上,一起共同眺望數字人技術的未來。 一、數字人技術體系重構 我們可以用三維定義對數字人技術進行框架重構 維度 技術內涵 典型特征 物理層 人體數字化建模技術 …

小剛說C語言刷題——1035 判斷成績等級

1.題目描述 輸入某學生成績,如果 86分以上(包括 86分)則輸出 VERY GOOD ,如果在 60到 85之間的則輸出 GOOD (包括 60和 85),小于 60 的則輸出 BAD。 輸入 輸入只有一行,包括 1個整數。 輸出 輸出只有一行&#xf…

React-在使用map循環數組渲染列表時須指定唯一且穩定值的key

在渲染列表的時候,我們須給組件或者元素分配一個唯一值的key, key是一個特殊的屬性,不會最終加在元素上面,也無法通過props.key來獲取,僅在react內部使用。react中的key本質是服務于diff算法, 它的默認值是null, 在diff算法過程中…

Zookeeper的通知機制是什么?

大家好,我是鋒哥。今天分享關于【Zookeeper的通知機制是什么?】面試題。希望對大家有幫助; Zookeeper的通知機制是什么? 1000道 互聯網大廠Java工程師 精選面試題-Java資源分享網 Zookeeper 的通知機制是其核心特性之一&#xf…

【LangChain實戰】構建下一代智能問答系統:從RAG架構到生產級優化

打破傳統問答系統的次元壁 當ChatGPT在2022年掀起AI革命時,開發者們很快發現一個殘酷現實:通用大模型在專業領域的表現如同拿著地圖的盲人,既無法理解企業私有數據,也無法保證事實準確性。這催生了RAG(檢索增強生成&a…