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

PL/SQL Oracle Discussion :

select + fonction d'agrégation+d'autres champs


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Mars 2011
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Mars 2011
    Messages : 49
    Par défaut select + fonction d'agrégation+d'autres champs
    Bonjour,

    je veux sélectionner une table avec une fonction d'agrégat (min) et sélectionner également d'autres colonnes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
      select min (sectiontypeid_pk), sectiontypedesc, sectiontypename
        from sectiontype
       where sectiontypeid_pk not in (select sectiontypeid_pk from sectiontype@BDPROD )
    group by sectiontypeid_pk;
    J'ai fais group by mais en vain
    ORA-00979: N'est pas une expression GROUP BY
    Est-ce que ce je peux faire ça autrement en conservant le min et les autres champs sélectionnés ?

  2. #2
    Membre Expert Avatar de ojo77
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Décembre 2010
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2010
    Messages : 680
    Par défaut
    Bonjour,

    Soit vous souhaitez avoir le minimum global de sectiontypeid_pk soit vous voulez le minimum relatif pour chaque tuple sectiontypedesc, sectiontypename.

    Dans le premier cas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT min (sectiontypeid_pk) over (order by sectiontypeid_pk) mpk
         , sectiontypedesc
         , sectiontypename
    FROM sectiontype
    WHERE sectiontypeid_pk NOT IN (SELECT sectiontypeid_pk 
                                   FROM sectiontype@BDPROD ) ;
    Dans le second cas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT min (sectiontypeid_pk)  mpk
         , sectiontypedesc
         , sectiontypename
    FROM sectiontype
    WHERE sectiontypeid_pk NOT IN (SELECT sectiontypeid_pk 
                                   FROM sectiontype@BDPROD )
    GROUP BY sectiontypedesc
           , sectiontypename ;

  3. #3
    Membre averti
    Inscrit en
    Mars 2011
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Mars 2011
    Messages : 49
    Par défaut
    Merci pour la réponse mais le résultat de la requête normalement une seule ligne je sais pas pourquoi la requête me retourne 2 lignes ayant la même clé primaire chose qui n'existe pas réellement dans la table sectiontype !!!!

    SVP vous pouvez me dire le rôle de la clause over dans ce cas ?!!

    Mercii pour votre aide

  4. #4
    Membre Expert
    Avatar de doc malkovich
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Juillet 2008
    Messages
    1 884
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 884
    Billets dans le blog
    1
    Par défaut
    Vous ne voulez pas plutôt la ligne avec l'id minimum ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      select sectiontypeid_pk, sectiontypedesc, sectiontypename
        from sectiontype
       where sectiontypeid_pk=( select min(b.sectiontypeid_pk) from sectiontype  b
             where b.sectiontypeid_pk not in (select sectiontypeid_pk from sectiontype@BDPROD ))
    group by sectiontypeid_pk;

  5. #5
    Membre averti
    Inscrit en
    Mars 2011
    Messages
    49
    Détails du profil
    Informations forums :
    Inscription : Mars 2011
    Messages : 49
    Par défaut
    Super Merci pour la réponse

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

Discussions similaires

  1. [AC-2010] Forcer la saisie d'un champ en fonction valeur d'un autre champ
    Par eric0512 dans le forum VBA Access
    Réponses: 3
    Dernier message: 15/02/2012, 17h43
  2. Réponses: 2
    Dernier message: 07/04/2009, 10h00
  3. [VBA] Remplir un champ en fonction d'un autre champ
    Par Amanck dans le forum Access
    Réponses: 6
    Dernier message: 18/05/2006, 10h12
  4. Réponses: 1
    Dernier message: 10/01/2006, 10h59
  5. Réponses: 7
    Dernier message: 06/01/2006, 10h47

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