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 :

Problème DML dans fonction


Sujet :

SQL Oracle

  1. #1
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut Problème DML dans fonction
    Bonjour, j'ai une erreur dml quand je veux exécuter cette fonction, quelqu'un pourrais m'aider, merci :

    select portail.resilier.AJOUTERRESILIATIONCONTACT(1406968, 2, 'Machin', 'Machin', '654', 22, to_date('03/01/2008', 'DD/MM/YYYY'), 2, to_date('11/05/2646', 'DD/MM/YYYY'), NULL, 9) from dual


    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
    FUNCTION ajouterresiliationcontact (
          p_expuid                 IN   resiliation_contact.expuid%TYPE,
          p_id_civilite            IN   resiliation_contact.id_civilite%TYPE,
          p_nom                    IN   resiliation_contact.nom%TYPE,
          p_prenom                 IN   resiliation_contact.prenom%TYPE,
          p_numero_telephone       IN   resiliation_contact.numero_telephone%TYPE,
          p_id_choix_resiliation   IN   resiliation_contact.id_choix_resiliation%TYPE,
          p_date_demande           IN   resiliation_contact.date_demande%TYPE,
          p_type_date_appel        IN   resiliation_contact.type_date_appel%TYPE,
          p_date_appel             IN   resiliation_contact.date_appel%TYPE,
          p_jour_appel             IN   resiliation_contact.jour_appel%TYPE,
          p_heure_appel            IN   resiliation_contact.heure_appel%TYPE
       )
          RETURN resiliation_contact.id_contact%TYPE
       IS
          l_id_contact   resiliation_contact.id_contact%TYPE;
       BEGIN
          SELECT s_resil_contact.NEXTVAL
            INTO l_id_contact
            FROM DUAL;
     
          INSERT INTO resiliation_contact
                      (id_contact, expuid, id_civilite, nom, prenom,
                       numero_telephone, id_choix_resiliation,
                       date_demande, type_date_appel, date_appel,
                       jour_appel, heure_appel
                      )
               VALUES (l_id_contact, p_expuid, p_id_civilite, p_nom, p_prenom,
                       p_numero_telephone, p_id_choix_resiliation,
                       p_date_demande, p_type_date_appel, p_date_appel,
                       p_jour_appel, p_heure_appel
                      );
     
          COMMIT;
     
          RETURN l_id_contact;
       END;

  2. #2
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Z3phur Voir le message
    Bonjour, j'ai une erreur dml quand je veux exécuter cette fonction, quelqu'un pourrait m'aider, merci :
    ça serait bien d'avoir le message d'erreur, non ?
    Il n'y aurait pas un problème d'initialisation de la séquence des fois ?

  3. #3
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut
    Voici l'erreur :

    ORA-14551: cannot perform a DML operation inside a query
    ORA-06512: at "PORTAIL.RESILIER", line 118

    cela se passe lors de l'insert

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Z3phur Voir le message
    ORA-14551: cannot perform a DML operation inside a query
    ORA-06512: at "PORTAIL.RESILIER", line 118
    Ah ben, oui, tu fais un select pour tester ta fonction qui fait un insert et Oracle ne veut et ne peut pas.

    Essaie-ça dans sql+ :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    begin
    portail.resilier.AJOUTERRESILIATIONCONTACT(1406968, 2, 'Machin', 'Machin', '654', 22, to_date('03/01/2008', 'DD/MM/YYYY'), 2, to_date('11/05/2646', 'DD/MM/YYYY'), NULL, 9);
    end;
    /

  5. #5
    Expert éminent
    Homme Profil pro
    Big Data / Freelance EURL
    Inscrit en
    Mars 2003
    Messages
    2 124
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Big Data / Freelance EURL

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 124
    Points : 7 291
    Points
    7 291
    Par défaut
    Comme je ne connaissais pas la réponse ->google -> il me renvoit sur developpez.net:

    [Pl/Sql] Insert ou Update dans une fonction

    de façon synthétique à moins d'utiliser pragma autonomous_transaction tu ne peux pas utiliser d'INSERT dans une fonction.

  6. #6
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut
    Merci pour vos réponses rapides

  7. #7
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut
    Merci voici une solution qui marche très bien pour tester ma fonction en laissant l'insert à l'intérieur.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    declare
    v integer;
    begin
     
    v:= resilier.AJOUTERRESILIATIONCONTACT(1406968, 2, 'Machin', 'Machin', '654', 22, to_date('03/01/2008', 'DD/MM/YYYY'), 2, to_date('11/05/2646', 'DD/MM/YYYY'), NULL, 9);
    dbms_output.put_line(v);
    end;
    /

  8. #8
    Invité
    Invité(e)
    Par défaut
    oups, effectivement, j'avais omis de capter la valeur de retour...
    Mon code était bon pour une procédure, pas pour une fonction...
    Mea culpa

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problème argument dans fonction
    Par flo1411 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 06/05/2013, 04h37
  2. Problème tableau dans fonction
    Par bob45510 dans le forum Débuter
    Réponses: 1
    Dernier message: 22/10/2011, 11h37
  3. Problème doublon dans fonction select
    Par roman67 dans le forum SQL
    Réponses: 10
    Dernier message: 31/07/2008, 13h09
  4. Réponses: 3
    Dernier message: 09/12/2005, 03h04
  5. Problème de date dans fonction utlisateur
    Par lutin2003 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 11/04/2005, 16h25

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