IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

SQL Oracle Discussion :

Erreur "Ressource busy"


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 8
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    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;

  2. #2
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    bonsoir,

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

    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

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 8
    Par défaut
    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.

  4. #4
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    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 : 5 611
    Par défaut
    Verifie que ta table n'est pas déjà bloquée avant de commencer à tester la procèdure.

  5. #5
    Membre Expert Avatar de scheu
    Inscrit en
    Juin 2007
    Messages
    1 506
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 1 506
    Par défaut
    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/

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo