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 :

Ma requête ne me donne pas le résultat escompté


Sujet :

Langage SQL

  1. #1
    Invité
    Invité(e)
    Par défaut Ma requête ne me donne pas le résultat escompté
    Bonjour

    J ai une table qui regroupe les cotes de references des chevaux dans des courses ainsi que leur rapport gagnant et placé.

    J aimerai pouvoir en une requete recuperer la somme des gains placés pour les 6 plus petites côtes ainsi que le nombre d'enregistrements qui ont servis à effectuer ce calcul car par exemple si je cherche les 8 premiere cotes dans une course de 6 partants, le calcul ne s effectura que sur 6 et on 8!

    Pour cela j ai fait une requete qui helas me retourne le nombre total des enregistrements et la somme totale de tous les places pour la course même s ils ne font pas partis de ces 6 premieres cotes :

    ma requete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select sum(place) as somme,count(id) as nombre from partants where id_course=1 order by coteref asc limit 0,6
    Je pourrais faire une premiere requete qui retourne les 6 premieres cotes et les placés et des calculs qui me permettraient d obtenir le resultat desiré mais j imaginais que cela etait possible en une seule requete.
    Pouvez vous me le confirmer et me donner un bon debut de piste ?

    merci pour votre aide

    stephane

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    On va supposer que vous êtes sous MySQL ?!?

    Vous pouvez essayer quelque chose comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT 
        SUM(place) AS somme
       ,COUNT(*) AS nombre 
    FROM (
        SELECT place
        FROM partants 
        WHERE id_course=1 
        ORDER BY coteref ASC 
        LIMIT 0,6
    ) AS T

  3. #3
    Invité
    Invité(e)
    Par défaut
    Merci cela fonctionne parfaitement toutefois j aimerai comprendre le 'AS T'

    Je precise que je suis sous sqlite, j avais oublié.

    Une derniere question :

    Ici je selection pour id_course=1, cet id je l ai extrait d'une requete precedente...
    J ai lu que je devais utiliser JOIN pour imbriquer une requete dans ma requete alors que vous n utilisez pas JOIN.

    Donc ma question, comment imbriquer une requete à la place de id_course=1 comme par exemple distint(id_course) where...

    Merci de vos conseils car je patauge un peu en sql (beaucoup serait bien plus convenable)
    Dernière modification par Invité ; 21/06/2014 à 14h29. Motif: SQlite

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    AS T est simplement un Alias pour la table dérivée de la sous requête.

    Pour le reste, il faudrait connaitre la requête utilisée pour récupérer l'id_course afin de pouvoir vous aider à l’intégrer.

  5. #5
    Invité
    Invité(e)
    Par défaut
    Merci

    Je fais par exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT id_course from courses where partants=10 and discipline like "plat" order by date asc limit 0,100

Discussions similaires

  1. Une requète qui ne donne pas le résultat attendu
    Par JeanNoel53 dans le forum Firebird
    Réponses: 1
    Dernier message: 17/12/2013, 10h23
  2. [AC-2007] Requête qui ne donne pas de résultats
    Par sami0701 dans le forum Requêtes et SQL.
    Réponses: 10
    Dernier message: 07/11/2013, 22h50
  3. Une requête qui ne donne pas le résultat attendu
    Par JeanNoel53 dans le forum Visual C++
    Réponses: 4
    Dernier message: 30/10/2013, 11h35
  4. [XL-2003] pb sur formule qui ne donne pas le résultat escompté
    Par midge dans le forum Excel
    Réponses: 2
    Dernier message: 06/02/2011, 15h49
  5. [GNUPlot] Multiplot qui ne donne pas le résultat escompté
    Par Nicocot dans le forum Autres langages
    Réponses: 0
    Dernier message: 24/11/2008, 20h05

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