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 :

select sur une liste de clef


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 82
    Points : 60
    Points
    60
    Par défaut select sur une liste de clef
    Bonjour,
    Voila j'ai une liste de clef correspondant a des personnes d'une table
    et je veux tous les selectioner je les ai ds un tableau et quand je les concatene
    j ai un message d erreur "Requete trop complexe" a partir de 255 clef (je suis sous ACCESS) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM table_personnes WHERE clef = " + t[0] + " OR clef = " + t[1] + .... + " clef = " + t[n]
    Voila avec plus de 255 "OR" a la suite il n'axcepte pas la requete.

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    je ne connais pas access
    mais si tu utilises un 'IN', tu as le même probleme?

  3. #3
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 118
    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 118
    Points : 28 510
    Points
    28 510
    Par défaut
    Arrivé à ce niveau de nombre de valeurs à tester, tu as tout intérêt à utiliser plutôt une table (temporaire) pour y stocker les valeurs à tester et requêter 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
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    CREATE TABLE 
        tempo 
        (   valeur xxx
        )
    ;
    INSERT INTO 
        tempo   (valeur) 
    VALUES  (t[0]);
    ....
    INSERT INTO 
        tempo   (valeur) 
    VALUES  (t[n]);
     
    SELECT  *
    FROM    table_personnes
    WHERE   clef IN 
            (   SELECT  valeur 
                FROM    tempo
            )
    ;
    ou
    SELECT  *
    FROM    table_personnes
    WHERE   EXISTS
            (   SELECT  1
                FROM    tempo
                WHERE   table_personnes.clef = tempo.valeur
            )
    ;

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 82
    Points : 60
    Points
    60
    Par défaut
    ok avec IN ca marche impec merci bien

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "SELECT * FROM table_personnes WHERE clef IN (" + t[0] + "," + t[1] + .... + "," + t[n] + ")"

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 18/07/2011, 18h12
  2. SELECT sur une liste de valeur
    Par Rams7s dans le forum PL/SQL
    Réponses: 8
    Dernier message: 19/05/2011, 16h30
  3. Select sur une liste de table
    Par H.ile dans le forum SQL
    Réponses: 0
    Dernier message: 28/07/2009, 14h54
  4. recuperer selection sur une liste deroulante
    Par skillipo dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 18/02/2008, 10h17
  5. select sur une liste chaînée
    Par wtfu dans le forum Langage SQL
    Réponses: 1
    Dernier message: 01/06/2006, 16h30

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