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 :

Moyenne sur deux select


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Inscrit en
    Mai 2005
    Messages
    77
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 77
    Points : 58
    Points
    58
    Par défaut Moyenne sur deux select
    Bonjour

    J'exécute les 2 requêtes suivantes (une fois avec la ligne en commentaire, et une fois sans commentaire).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    SELECT  count(*)
    FROM    tabledate AS tbl
    WHERE   EXISTS
            (   SELECT  0 
                FROM    tabledate AS der
                WHERE   tbl.id = der.id
                and     der.id in (1, 2, 3)
      --          and     tbl.etat= "OK"
                HAVING  tbl.date = MAX(der.date) 
            );
    La première requête me retourne 2 et la seconde 8, j'ai donc 25% de lignes sans erreur.

    Comment faire pour avoir ce résultat en une seule requête (le "in" concernant l'Id est un exemple, il s'agit d'un select sur une autre table en réalité).

    D'avance merci.

    Iza

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 849
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 849
    Points : 52 978
    Points
    52 978
    Billets dans le blog
    6
    Par défaut
    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
    30
    31
    32
    33
    34
    35
    -- résumé :
    SELECT count(*) AS NOMBRE, 'KO' AS ETAT
    FROM tabledate AS tbl
    WHERE EXISTS (SELECT 1
                  FROM   tabledate AS der
                  WHERE  tbl.id = der.id
                    and  der.id in (1, 2, 3)
                 -- and  tbl.etat= 'OK'
                  HAVING tbl.date = MAX(der.date))
    UNION ALL
    SELECT count(*) AS NOMBRE, 'OK' AS ETAT
    FROM tabledate AS tbl
    WHERE EXISTS (SELECT 1
                  FROM   tabledate AS der
                  WHERE  tbl.id = der.id
                    and  der.id in (1, 2, 3)
                    and  tbl.etat= 'OK'
                  HAVING tbl.date = MAX(der.date))
     
    -- pourcentage :
    SELECT CAST(count(*)  AS FLOAT) /
           (SELECT CAST(count(*)  AS FLOAT) /
            FROM tabledate AS tbl
            WHERE EXISTS (SELECT 1
                          FROM   tabledate AS der
                          WHERE  tbl.id = der.id
                            and  der.id in (1, 2, 3)
                         HAVING tbl.date = MAX(der.date)) * 100 AS POURCENT
    FROM tabledate AS tbl
    WHERE EXISTS (SELECT 1
                  FROM   tabledate AS der
                  WHERE  tbl.id = der.id
                    and  der.id in (1, 2, 3)
                    and  tbl.etat= 'OK'
                  HAVING tbl.date = MAX(der.date))
    Les chaines de caractères s'entourent d'apostrophes pas de guillemets !

    A +

  3. #3
    Membre du Club
    Inscrit en
    Mai 2005
    Messages
    77
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 77
    Points : 58
    Points
    58
    Par défaut
    Bonjour
    J'ai un peu remanié la requête pour mes besoins, mais en tous cas, un grand merdi pour ton aide !
    Iza

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

Discussions similaires

  1. select distint() sur deux tables
    Par nimbus_77 dans le forum Requêtes
    Réponses: 2
    Dernier message: 14/06/2008, 11h51
  2. SELECT sur deux tables
    Par Gaetch dans le forum Langage SQL
    Réponses: 1
    Dernier message: 13/07/2007, 15h40
  3. Select sur deux tables
    Par DJuL- dans le forum Requêtes
    Réponses: 2
    Dernier message: 01/03/2007, 14h40
  4. Select sur deux bases differentes
    Par Absolut Beauty dans le forum Langage SQL
    Réponses: 13
    Dernier message: 09/09/2005, 15h08
  5. pb avec select sur deux champs
    Par graphicsxp dans le forum Langage SQL
    Réponses: 7
    Dernier message: 22/03/2005, 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