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 :

Dead lock dans même procedure


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Vince7-7
    Homme Profil pro
    Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com
    Inscrit en
    Janvier 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com

    Informations forums :
    Inscription : Janvier 2007
    Messages : 125
    Par défaut Dead lock dans même procedure
    Bonjour,
    En 9iR2, comment un deadlock peut-il apparaitre dans une procédure sachant que les traitement se font en vrac sur une seule table contenant un trigger qui mets à jour une autre table?
    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
     
    begin
     
    curseur1
    loop
       FORALL INTCONT IN 1..tableau.COUNT SAVE EXCEPTIONS
         insert into table values(...);
    EXCEPTION WHEN DML_ERRORS THEN
                V_ERRORS := SQL%BULK_EXCEPTIONS.COUNT;
     
                FOR i IN 1..V_ERRORS
                LOOP
                  IF SQL%BULK_EXCEPTIONS(i).ERROR_CODE = -1 THEN
                    V_INDEX := SQL%BULK_EXCEPTIONS(i).ERROR_INDEX;
     
                    UPDATE table
                       SET c1  = NVL(tableau2(V_INDEX),0),
                             c2  = NVL(tableau3(V_INDEX),0),
                             c3  = NVL(tableau4(V_INDEX),0),
                             c4  = NVL(tableau5(V_INDEX),0),
                             c5  = SYSDATE
                     WHERE critere1
                        AND critere2
                        AND critere3;
                  END IF;
                END LOOP;
            END;
     
            FORALL INTCONT IN 1..tableau.COUNT
              UPDATE table
                 SET c1  = NVL(tableau2(V_INDEX),0),
                             c2  = NVL(tableau3(V_INDEX),0),
                             c3  = NVL(tableau4(V_INDEX),0),
                             c4  = NVL(tableau5(V_INDEX),0),
     
               WHERE critere1
                   AND critere2
                   AND critere3
                 AND   critere4;
     
     
          END LOOP;

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    A priori difficile sauf si une requête appelait du code PL/SQL qui démarre une transaction autonome. Est-ce le cas du trigger ? Si vous avez eu un deadlock il y a normalement un fichier trace côté serveur qui contient des informations sur les transactions concernées. Que contient-il ?

  3. #3
    Membre éclairé Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Par défaut
    Est-ce la table maj dans ta procédure et celle maj dans le trigger ont des contraintes d'intégrités ? plus précisement des FK

Discussions similaires

  1. Enchainement de requête dans une même procedure stockée
    Par dahu17 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 25/04/2007, 11h22
  2. [DEBUTANT] Une vue dans une procedure stockee ?
    Par Invité dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 25/02/2004, 11h57
  3. Pb de convertion dans les procedures stockées
    Par Yannesco dans le forum SQL
    Réponses: 3
    Dernier message: 08/01/2004, 10h24
  4. Réponses: 4
    Dernier message: 28/12/2003, 15h50
  5. [TP]code asm dans une procedure
    Par M.Dlb dans le forum Turbo Pascal
    Réponses: 3
    Dernier message: 17/08/2002, 20h43

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