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 confirmé
    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
    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 : 42
    Localisation : France

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    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 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    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 134
    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
            )
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  4. #4
    Membre confirmé
    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
    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, 17h12
  2. SELECT sur une liste de valeur
    Par Rams7s dans le forum PL/SQL
    Réponses: 8
    Dernier message: 19/05/2011, 15h30
  3. Select sur une liste de table
    Par H.ile dans le forum SQL
    Réponses: 0
    Dernier message: 28/07/2009, 13h54
  4. recuperer selection sur une liste deroulante
    Par skillipo dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 18/02/2008, 09h17
  5. select sur une liste chaînée
    Par wtfu dans le forum Langage SQL
    Réponses: 1
    Dernier message: 01/06/2006, 15h30

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