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 :

Erreur de logique sur lien OR


Sujet :

Langage SQL

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut Erreur de logique sur lien OR
    Bonjour,

    Dans ma requête, j'ai certainement une erreur de logique que je ne parviens pas à détecter.

    Dans une table GLIT_LITS qui liste tous les lits de la clinique, par unité de soins (NUMUS), je cherche à comptabiliser le nombre de lits qui ne sont pas fictifs (FICTIF = 0). Seulement, pour unité particulière (NUMUS = 26796), dans le comptage des lits, en plus des lits fictifs, je ne dois pas non plus comptabiliser les lits bébé (TYPE = 'BB').

    Voici la requête que j'ai écrite :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT NUMUS, count(*) as NBLIT1 FROM 
    GLIT_LITS 
    where ((NUMUS <> 26796) or (NUMUS = 26796 and TYPE <> 'BB'))  AND 
              FICTIF = 0 
    group by NUMUS 
    order by NUMUS;
    Cette requête ne me donne pas le nombre de lits corrects par unité et de plus, l'unité 26796 n'est pas reprise dans le résultat.

    Quelqu'un aurait une idée?

    Merci d'avance!

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    J'ai modifié ma requête comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT NUMUS, count(*) as NBLIT1 FROM 
    GLIT_LITS 
    where ((NUMUS <> 26796) or (NUMUS = 26796 and (TYPE is null or TYPE <> 'BB')))  AND 
              FICTIF = 0 
    group by NUMUS 
    order by NUMUS;
    Cela a résolu mon problème.

  3. #3
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 290
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 290
    Points : 13 004
    Points
    13 004
    Par défaut
    Bonjour,
    Je dirais que tu peux simplifier ta condition:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT NUMUS, count(*) as NBLIT1 FROM 
    GLIT_LITS 
    where ((NUMUS <> 26796) or (TYPE is null or TYPE <> 'BB'))  AND 
              FICTIF = 0 
    group by NUMUS 
    order by NUMUS

    En effet, comme tu ne testes que la colonne NUMUS dans la première partie du OR, il est inutile de faire le test inverse dans la deuxième partie.
    Tatayo.

  4. #4
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    De fait, merci!

  5. #5
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    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 453
    Points : 18 394
    Points
    18 394
    Par défaut
    Citation Envoyé par tatayo Voir le message
    En effet, comme tu ne testes que la colonne NUMUS dans la première partie du OR, il est inutile de faire le test inverse dans la deuxième partie.
    N'oublions pas nos amis les nulls.

    Prenons ce cas où j'ai combiné NUMUS sur l'ensemble {26796, 10, null}, avec TYPE sur l'ensemble {AA, BB, null} et FICTIF sur l'ensemble {0, 1} :
    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
    with glit_lits (NUMUS, TYPE, FICTIF) as
    (
    select 26796, 'AA', 0 from dual union all
    select    10, 'AA', 0 from dual union all
    select  null, 'AA', 0 from dual union all
    select 26796, 'BB', 0 from dual union all
    select    10, 'BB', 0 from dual union all
    select  null, 'BB', 0 from dual union all
    select 26796, null, 0 from dual union all
    select    10, null, 0 from dual union all
    select  null, null, 0 from dual union all
    select 26796, 'AA', 1 from dual union all
    select    10, 'AA', 1 from dual union all
    select  null, 'AA', 1 from dual union all
    select 26796, 'BB', 1 from dual union all
    select    10, 'BB', 1 from dual union all
    select  null, 'BB', 1 from dual union all
    select 26796, null, 1 from dual union all
    select    10, null, 1 from dual union all
    select  null, null, 1 from dual
    )
    La requête originale de dubitoph :
    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
      select numus
           , count(*) as nblit1
        from glit_lits 
       where (numus <> 26796
          or (numus  = 26796 
         and (type   is null
          or  type   <> 'BB')))
         and fictif  = 0 
    group by numus
    order by numus;
     
         NUMUS     NBLIT1
    ---------- ----------
            10          3
         26796          2
    La requête de tatayo :
    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
      select numus
           , count(*) as nblit1
        from glit_lits 
       where (numus <> 26796
          or type   is null
          or type   <> 'BB')
         and fictif  = 0 
    group by numus
    order by numus;
     
     
         NUMUS     NBLIT1
    ---------- ----------
            10          3
         26796          2
                        2
    Attention à la simplification qui n'est pas forcément ISO.

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

Discussions similaires

  1. Erreur sur lien ODBC (32bits) *.accdb
    Par Miyazaki dans le forum Access
    Réponses: 10
    Dernier message: 22/06/2016, 15h16
  2. Erreur 404 pour des liens sur la welcome page
    Par Roy Miro dans le forum Tomcat et TomEE
    Réponses: 4
    Dernier message: 01/05/2011, 19h49
  3. Réponses: 1
    Dernier message: 18/05/2010, 12h41
  4. Erreur sur lien hypertexte sous win mais pas linux ?
    Par g_barthe dans le forum wxPython
    Réponses: 2
    Dernier message: 09/07/2008, 19h53
  5. Réponses: 4
    Dernier message: 04/08/2006, 16h47

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