Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 18/05/2008, 13h46   #1
Invité de passage
 
Inscription : mars 2006
Messages : 8
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 8
Points : 1
Points : 1
Par défaut Erreur "Ressource busy"

Bonjour, je suis entrain de programmer une procédure modifier et j'ai une erreur de ressource busy à chaque que j'essaie de tester ma procédure et pourtant j'utilise une seule session. voici le code de ma Procédure:
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
PROCEDURE Modifier (Ancien IN Nageurs%ROWTYPE, Nouveau IN Nageurs%ROWTYPE)
IS
 cNom Nageurs.NOM%TYPE;
 cPrenom Nageurs.PRENOM%TYPE;
 cAnnee Nageurs.ANNEENAISS%TYPE;
 cSexe Nageurs.SEXE%TYPE;
 cClub Nageurs.CLUB%TYPE;
 cCodePostal Nageurs.CODEPOSTAL%TYPE;
 AnneeInfo InfoGenerales.ANNEEENCOURS%TYPE;
adr rowid;
 v_counter BINARY_INTEGER := 0;
 
BEGIN
   LOOP
    BEGIN
      v_counter:=v_counter+1;
     SELECT  Nom,Prenom,AnneeNaiss,Sexe,Club,CodePostal,rowid
     INTO cNom,cPrenom,cAnnee,cSexe,cClub,cCodePostal,adr
    FROM Nageurs WHERE  Nom LIKE Ancien.Nom AND Prenom LIKE Ancien.Prenom FOR UPDATE NOWAIT;
    EXIT;
 
    EXCEPTION
        WHEN GestionException.ExcRessBusy THEN
 
            DBMS_LOCK.SLEEP(1);
            IF v_counter>6 THEN EXIT; END IF;
        WHEN NO_DATA_FOUND THEN GestionException.Declencher (GestionException.ConstAucuneDonnee);
        WHEN TOO_MANY_ROWS then GestionException.Declencher (GestionException.ConstTooManyRows );    
    END;
   END LOOP;
 
     IF Nouveau.Sexe NOT LIKE 'M' AND Nouveau.Sexe NOT LIKE 'F' then raise GestionException.ExcSexeFalse;
              end IF;
          IF Nouveau.AnneeNaiss >=AnneeInfo then raise GestionException.ExcAnneeNaiss;
          end IF;
 
 
 
 UPDATE Nageurs SET Nom=Nouveau.Nom, Prenom=Nouveau.Prenom,AnneeNaiss=Nouveau.AnneeNaiss,
            Sexe = Nouveau.Sexe,Club=Nouveau.Club,CodePostal = Nouveau.CodePostal 
            WHERE rowid=adr;
 COMMIT;
 
EXCEPTION
 
  WHEN GestionException.ExcAnneeNaiss 
            THEN GestionException.Declencher (GestionException.ConstAnneeNaiss);
 
  WHEN GestionException.ExcSexeFalse 
            THEN GestionException.Declencher (GestionException.ConstSexe);
 
  WHEN INVALID_NUMBER THEN RAISE_APPLICATION_ERROR(-20015, 'Le numero entré est invalide');
 
  WHEN VALUE_ERROR THEN RAISE_APPLICATION_ERROR(-20016, 'La valeur entrée est invalide');
 
  WHEN OTHERS then GestionException.Declencher (GestionException.ConstIndetermine);
 
 
END Modifier;
themahg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2008, 00h21   #2
Rédacteur/Modérateur
 
Avatar de Vincent Rogier
 
vincent rogier
Inscription : juillet 2007
Messages : 2 355
Détails du profil
Informations personnelles :
Nom : vincent rogier
Âge : 34

Informations forums :
Inscription : juillet 2007
Messages : 2 355
Points : 3 108
Points : 3 108
bonsoir,

Ton soucis vient de l'option NOWAIT du select sur la table Najeurs

Citation:
ORA-00054: resource busy and acquire with NOWAIT specified
Cause: Resource interested is busy.
Action: Retry if necessary.
__________________
Vincent Rogier.

Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

OCILIB (C Driver for Oracle)

Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle
Vincent Rogier est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2008, 11h34   #3
Invité de passage
 
Inscription : mars 2006
Messages : 8
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 8
Points : 1
Points : 1
Citation:
Envoyé par vicenzo Voir le message
bonsoir,

Ton soucis vient de l'option NOWAIT du select sur la table Najeurs
bonjour, Je suis obligé d'utiliser cette option pour verouiller la table aux ou un autre utilisateur voudra modifier la même ressource en même temps. Ce pourquoi, j'aimerai savoir comment gerer cette situation et éviter le blockage.
themahg est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2008, 14h45   #4
Expert Confirmé Sénior
 
Avatar de mnitu
 
Homme Marius Nitu
Ingénieur développement logiciels
Inscription : octobre 2007
Messages : 3 320
Détails du profil
Informations personnelles :
Nom : Homme Marius Nitu
Localisation : France, Marne (Champagne Ardenne)

Informations professionnelles :
Activité : Ingénieur développement logiciels
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2007
Messages : 3 320
Points : 5 839
Points : 5 839
Verifie que ta table n'est pas déjà bloquée avant de commencer à tester la procèdure.
mnitu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/05/2008, 18h00   #5
Membre Expert
 
Avatar de scheu
 
Inscription : juin 2007
Messages : 1 497
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 1 497
Points : 1 485
Points : 1 485
Citation:
Envoyé par themahg Voir le message
Je suis obligé d'utiliser cette option pour verouiller la table aux ou un autre utilisateur voudra modifier la même ressource en même temps. Ce pourquoi, j'aimerai savoir comment gerer cette situation et éviter le blockage.
Même en enlevant le NOWAIT, aucun risque, si une autre session veut modifier en même temps, elle sera mise en attente par un lock temporaire sur la table tant que tu n'auras pas commité ou rollbacké, mais au moins la session concurrente ne recevra pas l'erreur ORA-00054
__________________
La théorie, c'est quand on sait tout mais que rien ne fonctionne.
La pratique, c'est quand tout fonctionne mais que personne ne sait pourquoi.
Ici, nous avons réuni théorie et pratique : Rien ne fonctionne ... et personne ne sait pourquoi !

Réplication de base avec Postgresql : http://scheu.developpez.com/tutoriel.../log-shipping/
scheu est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h29.


 
 
 
 
Partenaires

Hébergement Web