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 :

Selection complexe


Sujet :

Langage SQL

  1. #1
    Membre averti
    Inscrit en
    Juin 2006
    Messages
    570
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 570
    Points : 340
    Points
    340
    Par défaut Selection complexe
    (Re)Bonjour.
    A chaque fois je le dis, mais il faut vraiment que je me remette au SQL, parce que je ne sais plus rien faire du tous.

    Alors je vous explique mon problème, j'ai une table contenant entre autre une colonne NOM et une colonne NUMERO.
    J'effectue une requete sur cette table avec un trie par le nom, puis le numéro.

    J'appelle cette requete avec un code par défaut (par exemple ABC123), donc un code composé d'un nom et d'un numéro. Ce afin d'y ajouter une limite supplémentaire qui est :
    Que le les noms doivent être supérieur ou égale à ABC.
    Et, SI le nom est ABC, alors le numéro doit être supérieur à 123.


    Et le problème est que je n'arrive pas a représenter ceci.
    Je pensais faire ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    (...)
    WHERE
    (...)
    AND
        (
             ( MATABLE.NOM>= 'ABC')
        OR
             ( MATABLE.NOM= 'ABC' AND MATABLE.NUMEROINDIVIDU >= 123)
        )
    Mais cela ne marche pas, puisque je n'ai que les code dont le nom est ABC.

    Voyez vous le problème de ma requête, et surtout comment puis je faire pour le corriger ?

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 115
    Points : 28 480
    Points
    28 480
    Par défaut
    Au plus simple, avec UNION :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
        SELECT    ...
        FROM    ...
        WHERE    ...
            AND    matable.nom > 'ABC'
    UNION
        SELECT    ...
        FROM    ...
        WHERE    ...
            AND    matable.nom = 'ABC' 
            AND    matable.numeroindividu >= 123

  3. #3
    Membre averti
    Inscrit en
    Juin 2006
    Messages
    570
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 570
    Points : 340
    Points
    340
    Par défaut
    Merci, en fait je viens de réaliser que le problème n'était ca.
    En fait, supposons que j'ai
    ABC1
    ABC2
    ABC3
    ABC4
    ABC5
    DEF1
    DEF2
    DEF3
    DEF4
    DEF5

    Si, je ne veux que les individus qui ont un nom >=à ABC, et pour ceux qui ont comme nom ABC, ceux qui ont comme numéro >= à 3, or la ma première requète me les donnait tous.
    Je pense qu'il faut que je joue avec NOT pour avoir la bonne correspondance.

  4. #4
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut,
    Est-ce qu'il ne faut pas juste que tu remplaces ">=" par ">" dans la clause
    nom >= 'ABC' ?

  5. #5
    Membre averti
    Inscrit en
    Juin 2006
    Messages
    570
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 570
    Points : 340
    Points
    340
    Par défaut
    J'ai pu trouver, il fallait bien que je fasse un simple NOT en inversant ma condition. Merci bien pour votre aide ^^

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

Discussions similaires

  1. SELECT complexe (pour moi)
    Par Zorglu dans le forum Requêtes
    Réponses: 6
    Dernier message: 11/01/2007, 19h11
  2. select complexe à formuler
    Par gg2vig dans le forum Oracle
    Réponses: 5
    Dernier message: 18/12/2006, 17h18
  3. [Access] requête de sélection complexe
    Par Nycos62 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 23/06/2006, 11h35
  4. [oracle 9i]select complex
    Par jaoued dans le forum Oracle
    Réponses: 1
    Dernier message: 14/06/2006, 12h09
  5. [oracle 9i]update à partir d'une selection complexe
    Par Requin15 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 13/06/2006, 11h18

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