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 :

Eviter un doublon conditionnel


Sujet :

Langage SQL

  1. #1
    Membre expert
    Profil pro
    Dév
    Inscrit en
    Juin 2007
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Dév

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 162
    Points : 3 695
    Points
    3 695
    Par défaut Eviter un doublon conditionnel
    Bonjour,

    J'ai un problème un peu particulier.

    Dans ma base de données (ACCESS 2000), je possède 2 colonnes: Segment et Segment1.


    Ces colonnes sont de cette formes:


    |Seg |Seg1 |
    -------------
    | 510 | 510 |
    | 511 | 510 |
    | 512 | 512 |
    | 513 | 513 |



    Dans ma requête, j'ai un iff(Segment1<>"", Segment & "/" & segment1, segment); donc j'obtiens "511/510".

    Seulement, j'aimerais que lorsque la condition est vérifiée, on ne prend pas en compte le premier 510 ne soit pas sélectionner. J'ai testé avec le distincte mais rien à faire.

    Merci.

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    On peut avoir le texte de la requête ?

    Je pense qu'il vaudrait mieux une requête GROUP BY, si j'ai bien compris le besoin.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT seg, MAX(seg1)
    FROM la_table
    GROUP BY seg

  3. #3
    Membre expert
    Profil pro
    Dév
    Inscrit en
    Juin 2007
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Dév

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 162
    Points : 3 695
    Points
    3 695
    Par défaut
    Hum là difficile car j'ai beaucoup de colonnes sélectionnées avec beaucoup de jointures.


    Malheureusement il me faut qu'une seule colonne pour l'instant en version light j'ai :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT IIf(SEGMENT.SGM_ID<>[SEGMENT_1].[SEG_ID],SEGMENT.SGM_ID & "/" & SEGMENT_1.SEG_ID,SEGMENT.SGM_ID) AS Segment
     
    FROM SEGMENT LEFT JOIN SEGMENT AS SEGMENT_1 ON (SEGMENT.BUS_ID = SEGMENT_1.BUS_ID
     
     
    WHERE  (((SEGMENT.SGM_ID)>=500 And (SEGMENT.SGM_ID)=[SEGMENT].[SEG_ID]))
     
    ORDER BY SEGMENT.BUS_ID, SEGMENT.SGM_ID

    Edit : J'aimerais en fait que ça renvoit :
    ---------+
    |Segment|
    ---------+
    511/510
    512
    513
    etc

  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Et quel est le résultat de cette requête par rapport au résultat attendu ?

  5. #5
    Membre expert
    Profil pro
    Dév
    Inscrit en
    Juin 2007
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Dév

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 162
    Points : 3 695
    Points
    3 695
    Par défaut
    J'obtiens :

    Segment
    ---------
    510/511
    511
    512
    513
    etc

    je veux en fait donc vu que j'ai déjà concaténé le 510/511, éviter qu'un autre 511 soit de nouveau sélectionné.

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    861
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 861
    Points : 965
    Points
    965
    Par défaut
    Bonjour,

    Vous pouvez essayer NOT EXISTS :
    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
     
    SELECT IIf(SEGMENT.SGM_ID<>[SEGMENT_1].[SEG_ID],SEGMENT.SGM_ID & "/" & SEGMENT_1.SEG_ID,SEGMENT.SGM_ID) AS Segment
    FROM SEGMENT 
    LEFT JOIN SEGMENT AS SEGMENT_1 
         ON (SEGMENT.BUS_ID = SEGMENT_1.BUS_ID) 
    WHERE  SEGMENT.SGM_ID>=500 
    AND SEGMENT.SGM_ID=[SEGMENT].[SEG_ID]
    AND NOT EXISTS
    (
     SELECT * 
     FROM SEGMENT s
     JOIN SEGMENT AS s1 
          ON (s.BUS_ID = s1.BUS_ID
          AND s.SGM_ID<>s1.SEG_ID)
     WHERE s1.seg_id = segment.sgm_id
    )
    ORDER BY SEGMENT.BUS_ID, SEGMENT.SGM_ID

  7. #7
    Membre expert
    Profil pro
    Dév
    Inscrit en
    Juin 2007
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Dév

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 162
    Points : 3 695
    Points
    3 695
    Par défaut
    Merci,

    J'ai pu résoudre le problème avec cet exemple

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

Discussions similaires

  1. Après importation, eviter les doublons
    Par uloaccess dans le forum Access
    Réponses: 6
    Dernier message: 16/11/2005, 16h36
  2. [Débutant][XSLT]Eviter les doublons
    Par leminipouce dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 21/10/2005, 11h34
  3. hash et Tie , eviter les doublons
    Par bluecurve dans le forum Langage
    Réponses: 5
    Dernier message: 12/10/2005, 16h39
  4. Eviter les doublons
    Par cyrill.gremaud dans le forum ASP
    Réponses: 5
    Dernier message: 14/09/2005, 12h37
  5. [langage] 2 fichier dans 1 en evitant les doublons
    Par remixxl dans le forum Langage
    Réponses: 6
    Dernier message: 26/07/2004, 17h05

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