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

Oracle Discussion :

requete casse tete


Sujet :

Oracle

  1. #1
    Membre régulier Avatar de pseudobidon57
    Inscrit en
    Octobre 2006
    Messages
    133
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 133
    Points : 101
    Points
    101
    Par défaut requete casse tete
    Bonjour, je ceherche depuis un bon moment a résoudre la requete suivante, sans utiliser de curseur:
    retourner les employee dont le salaire est superieure à la moyenne des salaires de leur departement. il y a 2 tables concernées:
    la table employee qui contient les champs "employee_id", "salary", et la table department qui contient les champs "department_id" et "name"
    j'ai essayé (entre autre) le code suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select employee_id
    from employee
    where salary>
    (select e.employee_id, d.department_id, avg(e.salary)
    from employee e, department d
    where d.department_id=e.department_id
    group by e.employee_id, d.department_id);
    qui forcement ne marche pas vu que dans la sous requete, je retourne trois colonnes, alor que ma première requete en retourne une seule..:s, mais, je ne vois pas comment faire autrement, et je ne pense pas etre très loin de la solution.. si quelqu'un avait une petite idée, cela m'aiderai beaucoup, merci

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2002
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Et en ajoutant un autre select ? ça donne quoi ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT employee_id
    FROM employee
    WHERE salary>
    (SELECT AVERAGE FROM
    (SELECT e.employee_id, d.department_id, avg(e.salary) as AVERAGE
    FROM employee e, department d
    WHERE d.department_id=e.department_id
    GROUP BY e.employee_id, d.department_id));
    En fait je dis une énorme connerie, et comme je peux pas supprimer mon post...

  3. #3
    Membre régulier Avatar de pseudobidon57
    Inscrit en
    Octobre 2006
    Messages
    133
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 133
    Points : 101
    Points
    101
    Par défaut
    lol.. non, cela ne fonctionne toujours pas, mais il y a de l'idée.. merci

  4. #4
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Et cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT employee_id
    FROM employee e1
    WHERE salary>
    (SELECT avg(salary)
    FROM employee
    WHERE department_id=e1.department_id)
    GROUP BY e.employee_id, d.department_id);

  5. #5
    Futur Membre du Club
    Inscrit en
    Avril 2007
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    J'ai l'impression qu'il manque quelque chose car la sous requete doit ramener plusieurs lignes ?
    De plus, la moyenne des salaires est par département

    si ç'est ça, peut-être que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT emp.employee_id
    FROM employee emp
    WHERE emp.salary>(SELECT AVERAGE FROM
                                  (SELECT d.department_id, avg(e.salary) AS AVERAGE
                                   FROM employee e, department d
                                   WHERE d.department_id=e.department_id
                                   GROUP BY d.department_id) calcul
                              WHERE calcul.department_id = emp.department_id);

  6. #6
    Membre régulier Avatar de pseudobidon57
    Inscrit en
    Octobre 2006
    Messages
    133
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 133
    Points : 101
    Points
    101
    Par défaut
    oui parfaitement seb, la moyenne est par departement, c'etait mon principal souci, la requete fonctionne, genial!! Je vais juste verifier que les resultats soient juste, mais cela m'en a tout l'air.. Merci beaucoup..

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

Discussions similaires

  1. [2000] Un "casse tete" de requete :) Jointure avec conditions
    Par yepAccess dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 11/04/2008, 21h05
  2. casse tete sur une requete - probleme de Séléction
    Par tatayoyo dans le forum Langage SQL
    Réponses: 4
    Dernier message: 03/03/2007, 19h32
  3. Requete Casse tete... Help..
    Par Jerome218 dans le forum Requêtes
    Réponses: 2
    Dernier message: 24/01/2006, 05h57
  4. casse tete de requete
    Par moutey dans le forum Langage SQL
    Réponses: 2
    Dernier message: 14/12/2004, 14h00
  5. [casse-tete (pour moi)] recuperer la largeur d'un <div>
    Par Invité dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 05/11/2004, 07h39

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