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

Langage SQL Discussion :

procedure insertion


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    532
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 532
    Par défaut procedure insertion
    bonsoir,

    j ai creer une procedure d insertion sous sqlplus dans un package et quand je lance ma procedure j ai toujours ce message d erreur :

    SQL> execute sport.ajouter_sessions(2,'mardi','kk','kk','kkk','masculin',2,2);
    BEGIN sport.ajouter_sessions(2,'mardi','kk','kk','kkk','masculin',2,2); END;

    *
    ERREUR à la ligne 1 :
    ORA-06550: Ligne 1, colonne 7 :
    PLS-00306: numéro ou types d'arguments erronés dans appel à 'AJOUTER_SESSIONS'
    ORA-06550: Ligne 1, colonne 7 :
    PL/SQL: Statement ignored
    pourtant quand j essai d inserer ma ligne manuellement cela marche

    voila ma procedure pl sql :
    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
    procedure ajouter_sessions(id_session integer,
    jour varchar,
    heure_debut varchar,
    heure_fin varchar,
    lieu varchar,
    id_activite integer,
    id_professeur integer) is 
     
     
    session_dyn varchar(100);
    numsession integer;
    err_renseign exception;
    numsession_existe exception;
     
     
    BEGIN
     
     
     
          --On test si il manque des données entrée en paramètre. Si c'est le ca, on appelle une exception qui affichera un message d'erreur--
         IF (id_session IS NULL) or (jour  IS NULL) or (heure_debut  IS NULL)
        or (heure_fin   IS NULL) or (lieu   IS NULL) or (id_activite   IS NULL) or (id_professeur IS NULL) THEN
               RAISE err_renseign;
          END IF;
     
     
     
    --On utilise une requête dynamique pour tester si l id_session saisie existe déja dans la table sessions--
          session_dyn:= 'SELECT count(*) FROM sessions WHERE id_session= :p';
          EXECUTE IMMEDIATE session_dyn INTO numsession USING id_session;
     
     
     --Si l identifiant existe déja, on appelle une exception qui signalera le problème--
         IF numsession>0 THEN 
                RAISE numsession_existe;
          END IF;
     
    --On utilise une requête dynamique pour insérer les élements dans la table sessions --
         EXECUTE IMMEDIATE 
          'INSERT INTO sessions VALUES (:p1,:p2,:p3,:p4,:p5,:p6,:p7)'
         USING id_session,
          jour  ,
          heure_debut , 
          heure_fin ,
          lieu ,
          id_activite ,
          id_professeur ;
     
     
    EXCEPTION 
     
    WHEN numsession_existe THEN
             raise_application_error(-20501,'message erreur: l identifiant de la session existe déja- Insertion annuler');
     
     
    end;

    Merci d avance[/quote]

  2. #2
    Membre chevronné

    Développeur Web
    Inscrit en
    Mars 2002
    Messages
    412
    Détails du profil
    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2002
    Messages : 412
    Par défaut
    Tu as une chaîne de caractère en trop dans ton passage de paramètre :

    il y a 4 varchar là-dedans :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    procedure ajouter_sessions(id_session integer,
    jour varchar,
    heure_debut varchar,
    heure_fin varchar,
    lieu varchar,
    id_activite integer,
    id_professeur integer)
    ... et 5 là-dedans. Il faut faire un petit effort et on peut trouver tout seul pour ce genre de trucs.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     SQL> execute sport.ajouter_sessions(2,'mardi','kk','kk','kkk','masculin',2,2);

  3. #3
    Membre éclairé
    Inscrit en
    Janvier 2004
    Messages
    532
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 532
    Par défaut
    merci
    c'est vrai que j aurai du faire plus attention vu que j avais rajouter le sexe dans table j avais pas fait attention à sa dans la procedure.

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

Discussions similaires

  1. erreur de procedure insert
    Par gadalla dans le forum Delphi
    Réponses: 1
    Dernier message: 14/07/2007, 13h35
  2. procedure insertion image blob
    Par r83 dans le forum SQL
    Réponses: 1
    Dernier message: 08/05/2007, 12h49
  3. Pb procedure insertion ligne
    Par richton95 dans le forum Oracle
    Réponses: 3
    Dernier message: 17/03/2005, 21h01
  4. procedures stockees et insertion
    Par rlgrand dans le forum SQL
    Réponses: 2
    Dernier message: 03/05/2004, 14h49
  5. [PROCEDURE STOCKEE]Utilisation incorrecte de INSERT
    Par BaronSamdi dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 11/03/2004, 16h26

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