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

Requêtes MySQL Discussion :

Limiter le nombre de lignes retournées


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 39
    Points : 24
    Points
    24
    Par défaut Limiter le nombre de lignes retournées
    Bonjour à tous ,

    Je souhaiterais effectuer une requete du type

    Code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
      SELECT * 
      FROM table_A 
      LIMIT 0, ( 
                  SELECT nb_affichages 
                  FROM table_B 
                  WHERE TABLE = "table_A" 
                  )
    Mais il semble que ce soit impossible ... y'aurait-il moyen de contourner ce problème, ou sauriez-vous comment faire pour obtenir le résultat escompté ?

    merci d'avance

  2. #2
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 911
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 911
    Points : 6 032
    Points
    6 032
    Par défaut
    As-tu essayé en mettant un select count dans la ss-requète ?

    Limit attend des chiffres, et là tu lui fournis 0 et un ensemble de nb_affichages...
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 39
    Points : 24
    Points
    24
    Par défaut
    Oui j'ai bien sur essayé ( je partais du postulat, dans mon exemple, que le champ "table" de ma table table_B possédait une clef unique ).

    A vrai dire,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
      SELECT * 
      FROM table_A 
      LIMIT 0, ( 
                  SELECT 1
                  )
    ne marche pas non plus ... comment faire : / ?

  4. #4
    Membre éprouvé
    Avatar de Biglo
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    537
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2002
    Messages : 537
    Points : 984
    Points
    984
    Par défaut
    LIMIT n'accepte que des constantes numériques. Même pas de variable de session.

    Sauf dans un cas : les prepared statements.

    Tu peux faire quelque chose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT nb_affichages INTO @nb
    FROM table_B 
    WHERE TABLE = "table_A";
     
    PREPARE stmt FROM 'SELECT * FROM table_A LIMIT ?';
    EXECUTE stmt USING @nb;
    Mais bon, je suppose que tu utilises un autre langage que le SQL pour ton application. Le mieux serait quand même de récupérer le nombre avec une première requête SELECT, et de créer l'autre requête dans l'appli avant de l'envoyer au serveur.

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 39
    Points : 24
    Points
    24
    Par défaut
    Le problème vient en fait de l'utilisation que je veux faire de cette requete : je souhaitais l'imbriquer dans une requete "INSERT INTO ...", ca risque donc de poser problème ...

    Tant pis merci beaucoup pour votre aide je vais faire autrement .

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

Discussions similaires

  1. limiter le nombre de lignes retournées par un select
    Par l.saladdin dans le forum MySQL
    Réponses: 1
    Dernier message: 18/02/2010, 16h56
  2. Réponses: 5
    Dernier message: 02/04/2009, 09h24
  3. Réponses: 2
    Dernier message: 17/04/2008, 11h16
  4. Limiter le nombre d'enregistrements retournés
    Par Sydaze dans le forum Bases de données
    Réponses: 2
    Dernier message: 28/04/2005, 12h33
  5. Limiter le nombre de Ligne d'un RichEdit
    Par Argonz dans le forum C++Builder
    Réponses: 2
    Dernier message: 06/07/2004, 10h16

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