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

SQL Oracle Discussion :

Requête sql TOP 5


Sujet :

SQL Oracle

  1. #1
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 16
    Par défaut Requête sql TOP 5
    Bonjour tout le monde,
    Comment établir une requête SQL qui m'affiche les 5 top agences pour l'année 2012 ( selon la somme de leurs commissions)
    Résultat:
    agence som commission Année :2012
    agence 1 300000
    agence 2 200000
    ......
    .......
    agence 5 50000
    Merci de me répondre.

  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

  3. #3
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Lisez Top-N Queries
    Revenez avec votre requête par la suite si vous avez encore des difficultés.

  4. #4
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 16
    Par défaut
    Bonjour,
    Merci de votre aide.
    Voici la requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT
         "DIM_AGENCE"."NOM_AGENCE",
         sum("FAIT_ANALYSE_CARTE"."MONTANT_COMMISSIONTEMP")
    FROM
         "DIM_AGENCE" INNER JOIN "FAIT_ANALYSE_CARTE" ON "DIM_AGENCE"."ID_DIM_AGENCE" = "FAIT_ANALYSE_CARTE"."ID_DIM_AGENCE"
     
         order by  sum("FAIT_ANALYSE_CARTE"."MONTANT_COMMISSIONTEMP") DESC
     
      WHERE ROWNUM <= 5
    mais j'ai une erreur : la commande ne se termine pas correctement.
    Avez vous une idée?
    Merci d'avance

  5. #5
    Membre actif
    Homme Profil pro
    ingénieur d'étude PL/SQL
    Inscrit en
    Octobre 2002
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur d'étude PL/SQL

    Informations forums :
    Inscription : Octobre 2002
    Messages : 53
    Par défaut
    enlevez toutes les doubles cotes (")
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT
         DIM_AGENCE.NOM_AGENCE,
         sum(FAIT_ANALYSE_CARTE.MONTANT_COMMISSIONTEMP)
    FROM
         DIM_AGENCE INNER JOIN FAIT_ANALYSE_CARTE ON DIM_AGENCE.ID_DIM_AGENCE = FAIT_ANALYSE_CARTE.ID_DIM_AGENCE
         ORDER BY  sum(FAIT_ANALYSE_CARTE.MONTANT_COMMISSIONTEMP) DESC
      WHERE ROWNUM <= 5

  6. #6
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 16
    Par défaut
    Merci mais ça n'a pas marché.

  7. #7
    Membre actif
    Homme Profil pro
    ingénieur d'étude PL/SQL
    Inscrit en
    Octobre 2002
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur d'étude PL/SQL

    Informations forums :
    Inscription : Octobre 2002
    Messages : 53
    Par défaut
    mais encore !!!

    donnez le message d'erreur (ORA-....)

  8. #8
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 16
    Par défaut
    Voila la requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT * FROM (
     
     
    SELECT distinct 
    "DIM_AGENCE"."NOM_AGENCE",
    sum("FAIT_ANALYSE_CARTE_BIAT"."MONTANT_COMMISSIONTEMP")
    FROM
    "DIM_AGENCE" INNER JOIN "FAIT_ANALYSE_CARTE_BIAT" ON "DIM_AGENCE"."ID_DIM_AGENCE" = "FAIT_ANALYSE_CARTE_BIAT"."ID_DIM_AGENCE"
    order by sum("FAIT_ANALYSE_CARTE_BIAT"."MONTANT_COMMISSIONTEMP") DESC
    GROUP BY "DIM_AGENCE"."NOM_AGENCE")
    WHERE ROWNUM < 5
    L'erreur arentException:
    java.sql.SQLException: ORA-00907: parenthèse de droite absente
    plzz help

  9. #9
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Salut,
    Ton order by doit être placé après le GROUP BY, je pense.

  10. #10
    Membre confirmé
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Juin 2013
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2013
    Messages : 19
    Par défaut
    Bonjour,

    je vois deux points qui pourraient te permettre de faire fonctionner ta requête :

    • le premier est dans la citation de pacmann, l'ordre des clauses est important et GROUP BY doit être avant ORDER BY

    Citation Envoyé par pacmann Voir le message
    Salut,
    Ton order by doit être placé après le GROUP BY, je pense.

    • la deuxième est dans le fait de nommer la sous-requête...

    voici un exemple qui inclus également le fait de nommer les colonnes et de positionner des alias pour les tables.

    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
     
    SELECT tab.nom, tab.somme 
    FROM 
    (
    	SELECT DISTINCT 
    		a.NOM_AGENCE nom,
    		sum(f.MONTANT_COMMISSIONTEMP) somme
    	FROM DIM_AGENCE a
    	INNER JOIN FAIT_ANALYSE_CARTE_BIAT f
    		ON a.ID_DIM_AGENCE = f.ID_DIM_AGENCE
    	GROUP BY a.NOM_AGENCE
    	ORDER BY sum(f.MONTANT_COMMISSIONTEMP) DESC
    ) tab --alias pour la sous-requète...
    WHERE ROWNUM < 5
    ;
    Enfin dans cette exemple, j'ai ajouté une dernière "bonne pratique" celle de toujours nommé ces colonnes et d'éviter au maximun l'utilisation du caractère étoile (ou star ou *)

    en espérant t'avoir fournit de l'aide.

  11. #11
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 16
    Par défaut
    Merci à Tous.
    Problème résolu.
    Voila la bonne solution:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT * FROM (
        SELECT "DIM_AGENCE"."NOM_AGENCE", 
        SUM("FAIT_ANALYSE_CARTE_BIAT"."MONTANT_COMMISSIONTEMP") 
        FROM "DIM_AGENCE" INNER JOIN "FAIT_ANALYSE_CARTE_BIAT" 
        ON "DIM_AGENCE"."ID_DIM_AGENCE" = "FAIT_ANALYSE_CARTE_BIAT"."ID_DIM_AGENCE"
        GROUP BY "DIM_AGENCE"."NOM_AGENCE"
        ORDER BY SUM("FAIT_ANALYSE_CARTE_BIAT"."MONTANT_COMMISSIONTEMP") DESC
    ) 
    WHERE ROWNUM < 5

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

Discussions similaires

  1. Requête pour TOP SQL
    Par bibi92 dans le forum SQL
    Réponses: 3
    Dernier message: 03/07/2008, 17h41
  2. Requête SQL : récupérer un top rattaché à une colonne ?
    Par SetaSensei dans le forum Langage SQL
    Réponses: 3
    Dernier message: 07/02/2008, 18h24
  3. requête sql top
    Par babafredo dans le forum ASP
    Réponses: 3
    Dernier message: 10/09/2007, 17h39
  4. Requête SQL : top 10
    Par schdam dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 19/05/2007, 16h51
  5. [Requête SQL][ACCESS 2003] - Fonction TOP, DISTINCT
    Par guiguikawa dans le forum Requêtes et SQL.
    Réponses: 14
    Dernier message: 20/06/2006, 11h41

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