Outils personnels

Suppression de JOB Oracle 10g

De wikiGite

Révision datée du 17 novembre 2010 à 09:17 par Frank (discussion | contributions) (Page créée avec « == JOB lancé par l'application == Trouver l'identifiant du JOB (job=identifiant, what=contenu): select job,substr(what,1,20),next_date from dba_jobs; Est-il RUNNING ? : se... »)
(diff) ← Version précédente | Voir la version actuelle (diff) | Version suivante → (diff)

JOB lancé par l'application

Trouver l'identifiant du JOB (job=identifiant, what=contenu):

select job,substr(what,1,20),next_date from dba_jobs;

Est-il RUNNING ? :

select job,last_date from dba_jobs_running;

Tenter de le supprimer :

EXEC DBMS_JOB.REMOVE(<numéro du job>);

Si ça ne suffit pas, trouver la session qui a lancé le job :

SELECT job,s.sid,s.serial#,spid FROM dba_jobs_running d, v$session s, v$process p WHERE d.sid = s.SID AND s.PADDR = p.ADDR;

Les colonnes intéressantes sont SID et SERIAL#

Tuer la session correspondante :

alter system kill session <sid>,<serial#>;

en reprenant les valeurs trouvés dans la requête précédente.

JOB planifié dans Oracle

A TESTER.

On peut tenter :

BEGIN
 dbms_scheduler.drop_job( <job name> [,<force>] );
END;

Ou force est un booléen, à FALSE par défaut, qu'on peut mettre à TRUE.