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 :

La fonction Decode


Sujet :

PL/SQL Oracle

  1. #1
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2018
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Février 2018
    Messages : 44
    Par défaut La fonction Decode
    Bonjour,

    je dispose d'un paramètre appelé p_param avec comme valeurs soit 'Oui' soit 'Non'. J'aimerais si p_param = 'Oui', je ramène simplement 384, 2329 et 159. Si p_param = 'Non', je ramène tout.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     select champ1 
     from table1
     where 1=1 
     and table1.org_id in (11207, 384, 2959, 2329, 178, 159);
    Comment pourrais-je utiliser ma fonction DECODE ici ?

    Merci pour une aide éventuelle.

  2. #2
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2018
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Février 2018
    Messages : 44
    Par défaut
    Ou alors je pourrais utiliser un IF dans un begin.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    IF p_param = 'Non'
        THEN v_valeur := '%'
        ELSE v_valeur := 384, 2329 et 159 (c'est pas la bonne syntaxe, je ne sais pas encore ramener différentes valeurs dans une variable)
    END IF;

  3. #3
    Membre Expert
    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Décembre 2019
    Messages
    1 167
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Décembre 2019
    Messages : 1 167
    Par défaut
    Bonjour,

    Tu n'as pas besoin de decode, simplement des conditions and et or:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     select champ1 
     from table1
     where 1=1 
     and ((table1.org_id in (11207, 384, 2959, 2329, 178, 159) and p_param = 'Non') or (table1.org_id in (384, 2329, 159) and p_param = 'Oui')) ;

  4. #4
    Membre Expert
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Par défaut
    A quoi sert la sélection de valeurs lorsque le param = "non" si on ramène tout ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     select champ1 
     from table1
     where 1=1 
     and 
      (p_param = 'Non'
      or p_param = 'Oui' and (table1.org_id in (384, 2329, 159)
      );

  5. #5
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Ou même encore :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    select champ1 
      from table1
     where p_param = 'Non'
     union all
    select champ1 
      from table1
     where p_param = 'Oui'
       and org_id in (384, 2329, 159);
    L'intérêt c'est qu'une des deux parties de la requête sera toujours ignorée par l'optimiseur et l'autre sera facilement interprétée.

    Si vous êtes en PL/SQL vous pouvez en effet simplement faire quelque chose du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    IF p_param = 'Oui'
    THEN select champ1 into ... from table1 where org_id in (384, 2329, 159);
    ELSE select champ1 into ... from table1;
    END IF;

  6. #6
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2018
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Février 2018
    Messages : 44
    Par défaut
    Merci à toi, ça a fonctionné.

Discussions similaires

  1. équivalent DB2 à la fonction DECODE d'ORACLE
    Par jdlille dans le forum DB2
    Réponses: 2
    Dernier message: 29/03/2007, 11h23
  2. [parametres]JAVA fonction decode
    Par Yanos dans le forum Langage
    Réponses: 3
    Dernier message: 21/06/2006, 14h56
  3. [sql2005] cmdsql fonction DECODE
    Par delanfranchi dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 12/06/2006, 12h38
  4. Problème fonction decode()
    Par chti_juanito dans le forum Administration
    Réponses: 11
    Dernier message: 15/02/2006, 20h00
  5. Fonction decode
    Par nad dans le forum Oracle
    Réponses: 7
    Dernier message: 30/12/2005, 15h39

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