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

PL/SQL Oracle Discussion :

Gestion d'une transaction dans une procédure stockée


Sujet :

PL/SQL Oracle

  1. #1
    Membre habitué
    Inscrit en
    Novembre 2004
    Messages
    415
    Détails du profil
    Informations forums :
    Inscription : Novembre 2004
    Messages : 415
    Points : 138
    Points
    138
    Par défaut Gestion d'une transaction dans une procédure stockée
    Bonjour,
    Si on considère le code suivant :
    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
    CREATE OR REPLACE PROCEDURE DOUPDATES
    (
      VAL1 IN VARCHAR2
    , res out number
    , errorText out varchar2) as
    err exception;
    begin
     
    --start transaction;
    res := 0;
    errorText := '';
     
    if VAL1 is null then
    	res := -1;
    	errorText := 'val1 is mandatory';
    	raise err;
    end if;
     
    --firstInsert
    insert into table1 (...)
    select ...
    from table1
    where ...;
     
    --secondInsert
    insert into table2 (...)
    select ...
    from table2
    where ...;
     
    --thirdInsert
    insert into table3 (...)
    select ...
    from table3
    where ...;
     
    ...
     
    dbms_output.put_line('WENT FINE');
     
    commit;
     
    Exception
       when err then
          dbms_output.put_line('WENT WRONG');
          rollback;
       when others then
          dbms_output.put_line('WENT WRONG');
          res := SQLCODE;
          errorText := SUBSTR(SQLERRM, 1, 100);
    	  rollback;
     
    null;
    END DOUPDATES;
    Appel de la manière suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    declare
    	VAL1 VARCHAR2(12);
    	res number;
    	errorText varchar2(32767);
    begin
    	VAL1 := 'toto';
    	DOUPDATES(VAL1, res, errorText);
    	if res != 0 then
    		dbms_output.put_line('An error occured : ''' || errorText || '''');
    	else
    		dbms_output.put_line('OK');
    	end if;
    end;
    1/ Je ne comprends pas pourquoi le "start transaction;" fait planter la compilation quand je le décommente (c'est mon premier code en PL/SQL après des années de T-SQL...) ? Je me demande du coup si ma gestion de transaction est correcte (sans rentrer dans la problématique de savoir s'il vaut mieux gérer les transactions par le code appelant la procédure stockée) ?

    2/ Est-ce qu'en PL/SQL, on peut faire des gestions de transactions imbriquées ?

    Merci pour vos retours,

  2. #2
    Rédacteur/Modérateur

    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Décembre 2013
    Messages
    4 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2013
    Messages : 4 049
    Points : 9 384
    Points
    9 384
    Par défaut
    Sous Oracle PL/SQL, la gestion des transactions est automatique. Tu n'as pas besoin de dire Start-Transaction, puisque la 1ère instruction que tu lances ouvre une Transaction.
    Par contre, tu as besoin de fermer ta transaction (par un commit ou un RollBack).
    Quand tu fais un commit ou un rollback, ca cloture les instructions déjà passées, en les validant, ou en les effaçant, et ça remet les compteurs à zéro. Autrement dit, la prochaine instruction ouvrira automatiquement une nouvelle transaction.

    A ma connaissance, c'est le fonctionnement par défaut. Tu dois pouvoir faire un 'Set autocommit on' au niveau de la session, mais dans ce cas, j'imagine que tu n'as plus du tout la possibilité de gérer les transactions.
    N'oubliez pas le bouton Résolu si vous avez obtenu une réponse à votre question.

  3. #3
    Membre habitué
    Inscrit en
    Novembre 2004
    Messages
    415
    Détails du profil
    Informations forums :
    Inscription : Novembre 2004
    Messages : 415
    Points : 138
    Points
    138
    Par défaut
    Merci pour ce retour.
    Cependant, à quoi sert du coup l'expression "start transaction" qui peut bel et bien exister parfois en PL/SQL ?

    Et quid également de la possibilité de faire des gestions de transactions imbriquées ?

  4. #4
    Expert éminent
    Avatar de pachot
    Homme Profil pro
    Developer Advocate YugabyteDB
    Inscrit en
    Novembre 2007
    Messages
    1 821
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Developer Advocate YugabyteDB
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 821
    Points : 6 443
    Points
    6 443
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    Citation Envoyé par jmclej Voir le message
    Cependant, à quoi sert du coup l'expression "start transaction" qui peut bel et bien exister parfois en PL/SQL ?
    Où?

    Citation Envoyé par jmclej Voir le message
    Et quid également de la possibilité de faire des gestions de transactions imbriquées ?
    Autonomous transactions

    Cordialement,
    Franck.
    Franck Pachot - Developer Advocate Yugabyte 🚀 Base de Données distribuée, open source, compatible PostgreSQL
    🗣 twitter: @FranckPachot - 📝 blog: blog.pachot.net - 🎧 podcast en français : https://anchor.fm/franckpachot

Discussions similaires

  1. [XL-2007] Afficher une checkbox dans une feuille si une checkbox d'une autre feuille est cochée
    Par JessieCoutas dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/08/2009, 13h35
  2. portée d'une variable dans une fonction dans une méthode
    Par laurentg2003 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 29/06/2009, 19h05
  3. [POO] dans une classe, appeler une fonction dans une méthode
    Par arnaudperfect dans le forum Langage
    Réponses: 3
    Dernier message: 26/08/2007, 23h04
  4. Envoyer une formulaire dans une page dans une Frame
    Par zooffy dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 29/06/2007, 10h13
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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