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 Procédural MySQL Discussion :

Problème avec valeur de retour d'une fonction


Sujet :

SQL Procédural MySQL

  1. #1
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Points : 41
    Points
    41
    Par défaut Problème avec valeur de retour d'une fonction
    Bonjour,

    J'ai un petit souci avec une valeur de retour d'une fonction. Évidemment ça doit être une erreur toute bête, mais le nez dedans, l'erreur, je la vois pas.

    L'erreur mysql que je reçois lorsque je veux créer cette fonction c'est l'errorcode 1320 qui correspond à "pas de valeur de retour pour la fonction.

    Voici la fonction:
    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
     
    CREATE FUNCTION add_user (p1 varchar(60),p2 varchar(100),p3 varchar(60),p4 varchar(60),p5 varchar(60),p6 varchar(120),p7 varchar(60),p8 date,fk_group int,fk_player int,fk_country int) RETURNS INT
    BEGIN
     
    DECLARE v_login,v_login_tm,v_email varchar(60) default null;
    DECLARE v_fk_group,v_fk_player,v_fk_country INT DEFAULT 0;
    DECLARE var1 int default 0;
     
          SELECT login INTO v_login FROM users
          WHERE login=p1;
          SELECT tm_login INTO v_login_tm FROM users
          WHERE tm_login=p3;
          SELECT email INTO v_email FROM users
          WHERE email=p7;
          SELECT id_country INTO v_fk_country FROM country
          WHERE id_country = fk_country;
     
          IF v_login != null THEN
          SET var1=1;
                  ELSEIF v_tm_login != null THEN
                  SET var1=2;
                          ELSEIF v_email != null THEN
                          SET var1=3;
                                  ELSE
                                        insert into users (login,password,login_tm,first_name,last_name,adress,email,last_logon,fk_id_group,fk_id_player,fk_id_country)
                                        values (p1,p2,p3,p4,p5,p6,p7,p8,1,null,v_fk_country);
                          END IF;
                  END IF;
          END IF;
     
          return var1;
    END
    Pourquoi ce code ne passe pas ?
    Où est l'erreur ?

    D'avance merci.
    Franck.

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    IF v_login != NULL ne sera jamais vérifié. Il faut utiliser IS NOT NULL. Tu devrais également mettre un ELSE pour le cas où v_login est NULL.
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  3. #3
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Points : 41
    Points
    41
    Par défaut
    Merci de la réponse

    Alors voilà maintenant ce que j'ai:

    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
     
    CREATE FUNCTION add_user (p1 varchar(60),p2 varchar(100),p3 varchar(60),p4 varchar(60),p5 varchar(60),p6 varchar(120),p7 varchar(60),p8 date,fk_group int,fk_player int,fk_country int) RETURNS INT
    BEGIN
     
    DECLARE v_login,v_login_tm,v_email varchar(60) DEFAULT NULL;
    DECLARE v_fk_group,v_fk_player,v_fk_country INT DEFAULT 0;
    DECLARE var1 int DEFAULT 0;
     
          SELECT login INTO v_login FROM users
          WHERE login=p1;
          SELECT tm_login INTO v_login_tm FROM users
          WHERE tm_login=p3;
          SELECT email INTO v_email FROM users
          WHERE email=p7;
          SELECT id_country INTO v_fk_country FROM country
          WHERE id_country = fk_country;
     
          IF v_login IS NOT NULL THEN
          SET var1=1;
                  ELSEIF v_tm_login IS NOT NULL THEN
                  SET var1=2;
                          ELSEIF v_email IS NOT NULL THEN
                          SET var1=3;
                                  ELSE
                                        insert into users (login,pass,login_tm,first_name,last_name,adress,email,last_logon,fk_id_group,fk_id_player,fk_id_country)
                                        values (p1,p2,p3,p4,p5,p6,p7,p8,1,null,v_fk_country);
                          END IF;
                  END IF;
          END IF;
     
          RETURN var1;
    END
    Et ça ne fonctionne toujours pas :s

    D'autres idées ?

    D'avance merci.
    Franck.

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    et si tu rajoutais var1=0 dans ton ELSE ?
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  5. #5
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Points : 41
    Points
    41
    Par défaut
    Rha, toujours pas

    Voici le code de ma fonction maintenant:
    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
     
    CREATE FUNCTION `tmallstars`.`add_user2` (p1 varchar(60),p2 varchar(100),p3 varchar(60),p4 varchar(60),p5 varchar(60),p6 varchar(120),p7 varchar(60),p8 date,fk_group int,fk_player int,fk_country int) RETURNS INT
    BEGIN
     
    DECLARE v_login,v_login_tm,v_email varchar(60) DEFAULT NULL;
    DECLARE v_fk_group,v_fk_player,v_fk_country INT DEFAULT 0;
    DECLARE var1 int DEFAULT 0;
     
          SELECT login INTO v_login FROM users
          WHERE login=p1;
          SELECT login_tm INTO v_login_tm FROM users
          WHERE login_tm=p3;
          SELECT email INTO v_email FROM users
          WHERE email=p7;
          SELECT id_country INTO v_fk_country FROM country
          WHERE id_country = fk_country;
     
          IF v_login IS NOT NULL THEN
          SET var1=1;
                  ELSEIF v_tm_login IS NOT NULL THEN
                  SET var1=2;
                          ELSEIF v_email IS NOT NULL THEN
                          SET var1=3;
                                  ELSE
                                        INSERT INTO users (login,pass,login_tm,first_name,last_name,adress,email,last_logon,fk_id_group,fk_id_player,fk_id_country)
                                        VALUES (p1,p2,p3,p4,p5,p6,p7,p8,1,NULL,v_fk_country);
                                        SET var1=0;
                          END IF;
                  END IF;
          END IF;
     
          RETURN var1;
     
    END
    En tout cas merci pour l'aide

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    Comment tu appelles ta fonction ?
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  7. #7
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Points : 41
    Points
    41
    Par défaut
    C'est à la création de la fonction que j'ai l'erreur...

    Donc je ne l'appelle pas encore :s


    Voici l'erreur que j'ai: http://img223.imageshack.us/img223/1...urmysqlmt2.jpg

  8. #8
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    ah, fallait commencer par là ! à tous les coups, c'est une histoire de ;

    c'est quoi, ton client avec une drôle de tronche ?
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  9. #9
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Points : 41
    Points
    41
    Par défaut
    Outch, désolé, huhu.

    J'utilise Mysql Query Browser là (avec MySQL v5.1). Et j'utilise le tool de création de Procédure/Fonction inclus dans le GUI pour créer ma fonction... peut-être devrais-je directement passer par le scripting... je vais essayer.

    Encore désolé.
    Franck.

  10. #10
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    Citation Envoyé par ouranos21 Voir le message
    Outch, désolé, huhu.

    J'utilise Mysql Query Browser là (avec MySQL v5.1). Et j'utilise le tool de création de Procédure/Fonction inclus dans le GUI pour créer ma fonction... peut-être devrais-je directement passer par le scripting... je vais essayer.

    Encore désolé.
    Franck.
    Non, si tu utilises bien le machin de création de script, ça devrait passer...

    Si tu me donnes les CREATE TABLE nécessaire, je ferai un test ce soir.
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  11. #11
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 741
    Points
    11 741
    Par défaut
    En fait c'est ta syntaxe qui est mauvaise. Il ne faut pas mettre un END IF pour chaque ELSEIF, mais un seul END IF à la fin de l'ensemble :

    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
    CREATE FUNCTION add_user (p1 varchar(60),p2 varchar(100),p3 varchar(60),p4 varchar(60),p5 varchar(60),p6 varchar(120),p7 varchar(60),p8 date,fk_group int,fk_player int,fk_country int) RETURNS INT
    BEGIN
     
    DECLARE v_login,v_login_tm,v_email varchar(60) DEFAULT NULL;
    DECLARE v_fk_group,v_fk_player,v_fk_country INT DEFAULT 0;
    DECLARE var1 int DEFAULT 0;
     
          SELECT login INTO v_login FROM users
          WHERE login=p1;
          SELECT tm_login INTO v_login_tm FROM users
          WHERE tm_login=p3;
          SELECT email INTO v_email FROM users
          WHERE email=p7;
          SELECT id_country INTO v_fk_country FROM country
          WHERE id_country = fk_country;
     
          IF v_login != NULL THEN
    		SET var1=1;
          ELSEIF v_tm_login != NULL THEN
    		SET var1=2;
    	  ELSEIF v_email != NULL THEN
            SET var1=3;
    	  ELSE
    		INSERT INTO users (login,password,login_tm,first_name,last_name,adress,email,last_logon,fk_id_group,fk_id_player,fk_id_country)
            VALUES (p1,p2,p3,p4,p5,p6,p7,p8,1,NULL,v_fk_country);
          END IF;
     
          RETURN var1;
    END
    Antoun
    Expert Tableau, Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  12. #12
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Points : 41
    Points
    41
    Par défaut
    C'est bon à savoir en tout cas. Merci beaucoup :-)

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 02/05/2011, 19h23
  2. Réponses: 4
    Dernier message: 19/01/2009, 11h12
  3. Réponses: 5
    Dernier message: 14/06/2008, 13h30
  4. Réponses: 5
    Dernier message: 13/06/2007, 15h05
  5. Réponses: 5
    Dernier message: 18/09/2006, 14h17

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