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 :

Select avec une "sous-requête"


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2008
    Messages
    240
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Mai 2008
    Messages : 240
    Par défaut Select avec une "sous-requête"
    Bonjour,

    Je dois réaliser un select un peu spécial sur cette table :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    CREATE TABLE IF NOT EXISTS `itmmaster` (
      `itmref` varchar(20) NOT NULL,
      `itmdes1` varchar(30) NOT NULL,
      `itmdes2` varchar(30) NOT NULL,
      `itmdes3` varchar(30) NOT NULL,
      `eancod` bigint(13) NOT NULL,
      `itmsta` int(1) NOT NULL,
      `rplitm` varchar(20) NOT NULL
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
     
    ALTER TABLE `itmmaster`
     ADD PRIMARY KEY (`itmref`);
    itmref correspond à la référence, itmsta correspond au status de la référence, rplitm correspond à une référence de remplacement.

    Ma requête de base

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT itmmaster.itmref_0||'|'||itmmaster.itmdes1_0||'|'||itmmaster.itmdes2_0||'|'||itmmaster.itmdes3_0||'|'||itmmaster.eancod_0||'|'||itmmaster.itmsta_0||'|'||itmmaster.rplitm_0                                                                                              
    FROM itmmaster itmmaster
    WHERE itmmaster.ynonprepa_0 < 2 AND itmmaster.yflggen_0 < 2
    ORDER BY itmmaster.itmref_0;
    itmsta peut avoir comme valeur : 1, 2, 3, 4, 5, 6

    Je souhaite que lorsque itmsta = 6 éliminer les lignes dont rplitm est vide ou null.

    Je ne sais pas si c'est réalisable mais l'idée est d'éviter un retraitement lors de l'import dans une base mysql.

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour

    Il suffit d'ajouter une clause dans le WHERE :

    AND (itmsta <> 6 OR COALESCE(rplitm, '') <> '' )

  3. #3
    Membre éclairé
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2008
    Messages
    240
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Mai 2008
    Messages : 240
    Par défaut
    Parfait ça marche.

    Merci.

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

Discussions similaires

  1. [WD9] Requête de type SELECT avec une formule mathémathique
    Par jo_la_pasteque dans le forum WinDev
    Réponses: 2
    Dernier message: 22/04/2008, 12h42
  2. Requête selection avec une variable de date
    Par kahmsin dans le forum Access
    Réponses: 7
    Dernier message: 20/11/2005, 19h38
  3. [JDBC] Requête avec une date sous la forme dd/MM/yyyy
    Par sylviefrfr dans le forum JDBC
    Réponses: 6
    Dernier message: 12/11/2005, 09h35
  4. [Débutant] Requête SELECT avec max et sous-requête
    Par joefou dans le forum Langage SQL
    Réponses: 2
    Dernier message: 27/07/2005, 14h28

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