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 :

combient de if elsif je peux utiliser dans une pl


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 98
    Points : 68
    Points
    68
    Par défaut combient de if elsif je peux utiliser dans une pl
    Bonjour
    je suis entraine d'écrire une plsql sous oracle. il faut que je teste la valeur retourner par une requête. 12 résultat possible. j'utilise le bout de code suivante
    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 OR REPLACE FUNCTION .............
    prendre VARCHAR2(50);
    begin         
               select distinct p.codegrilletaille into grilleTaille
               from mim_produits p, mim_produits_coloris pc
               where p.codeproduit = pc.codeproduit
               and p.codeproduit = LeCodeProduit
               and pc.codecoloris = LeCodeColoris; 
               if (grilleTaille = 1) then 
                prendre := 'TU';
               elsif (grilleTaille = 2) then
                prendre := 'T1';
               elsif (grilleTaille = 3) then
                prendre := '36';
               elsif (grilleTaille = 4) then
                prendre := 'XS';
               elsif (grilleTaille = 5) then
                prendre := '90 B';
               elsif (grilleTaille = 6) then
                prendre := 'idéalement 38 mais prendre la taille disponible';
               elsif (grilleTaille = 7) then
                prendre := 'idéalement 85 mais prendre la taille disponible';
               elsif (grilleTaille = 8) then
                prendre := '0';
               elsif (grilleTaille = 9) then
                prendre := 'TU';
               elsif (grilleTaille = 10) then
                prendre := 'XS';
               end if; 
       return prendre;
    end;
    jusqu'à comme ici ça marche. par contre si j'ajoute une nouvelle bloc elsif il m'affiche l'erreur suivante
    PLS-00103: Encountered the symbol "end-of-file" when expecting one of the following:

    begin case declare end exit for goto if loop mod null pragma
    raise return select update while with <identifi
    est ce que vous avez une idée SVP. merci d'avance.

  2. #2
    Membre averti Avatar de xdescamp
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 300
    Points : 442
    Points
    442
    Par défaut
    Essaye de les regrouper (1 et 9 ou 4 et 10 par ex.).
    Sinon tu peux essayer l'instruction CASE
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CASE grilleTaille
      WHEN 1 THEN prendre := 'TU';
      WHEN 2 THEN prendre := 'T1';
    etc...
    END CASE;

  3. #3
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Je ne connais pas de limitation, j'ai déjà été bien au delà de 12.
    Un problème sans solution est un problème mal posé

    Merci de poser vos questions sur le forum, je ne réponds pas aux questions posées par MP.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 98
    Points : 68
    Points
    68
    Par défaut
    Merci beaucoup pour la réponse. avec case sa marche très bien. par contre je comprend pas toujours pour quoi sa marcher pas avec les if elsif. sa m as paru bizarre surtout que plaineR dit qu'il y a pas de limite?

  5. #5
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Peut-être une faute de frappe ?
    Un problème sans solution est un problème mal posé

    Merci de poser vos questions sur le forum, je ne réponds pas aux questions posées par MP.

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 98
    Points : 68
    Points
    68
    Par défaut
    peut être mais je croix pas. de toute façon merci beaucoup pour les réponses.

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

Discussions similaires

  1. Peux-t-on connaître les différentes profondeurs utilisées dans une anim flash ?
    Par Dsphinx dans le forum ActionScript 1 & ActionScript 2
    Réponses: 11
    Dernier message: 13/12/2011, 08h36
  2. [VBA-E]type de donnée range en vba utilisée dans une feuille
    Par Yoyo51 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 30/03/2006, 10h26
  3. Impossible d'utiliser & dans une chaîne de caractère
    Par gingman dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 16/03/2006, 20h35
  4. [FREETEXT][Sql2000] Utilisation dans une requête ?
    Par SoaB dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 18/10/2005, 14h49
  5. valeur d'un champ pour l'utiliser dans une requete
    Par bachilbouzouk dans le forum ASP
    Réponses: 4
    Dernier message: 08/04/2005, 16h58

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