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 :

Comment fonctionne le SGDB


Sujet :

Oracle

  1. #1
    Candidat au Club
    Femme Profil pro
    future ingenieur
    Inscrit en
    Décembre 2013
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : future ingenieur

    Informations forums :
    Inscription : Décembre 2013
    Messages : 1
    Points : 3
    Points
    3
    Par défaut Comment fonctionne le SGDB
    bonjour
    j'ai la requête suivante:
    donner les départements ayant plus qu’une secrétaire.
    la solution est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select numD,count(*)
    from emp
    group by numD 
    having count(*) >1 ;
    je veux savoir comment le SGBD connait que count(*) revient au nombre de secrétaire ?

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    count(*) c'est le nombre de lignes, si tous les employés sont des secrétaires alors ce nombre de lignes correspond au nombre de secrétaire, sinon il est nécessaire de filtrer sur le job secrétaire...

  3. #3
    Membre régulier Avatar de Sakukun
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2011
    Messages
    74
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2011
    Messages : 74
    Points : 113
    Points
    113
    Par défaut
    Bonjour,
    c'est parce que ta table est simple ou contient que les information que tu veux

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    with emp AS (SELECT 1 AS id, 1 AS numD FROM dual union ALL
    SELECT 2 AS id, 1 AS numD FROM dual union ALL
    SELECT 3 AS id, 2 AS numD FROM dual union ALL
    SELECT 4 AS id, 3 AS numD FROM dual )
    SELECT numD,count(id)
    FROM emp
    GROUP BY numD 
    HAVING count(*) >1 ;
    =
    Si tu prend ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    with emp AS (SELECT 1 AS id, 1 AS numD, 's' as type_Metier FROM dual union ALL
    SELECT 2 AS id, 1 AS numD, 'e' as type_Metier FROM dual union ALL
    SELECT 3 AS id, 2 AS numD, 's' as type_Metier FROM dual union ALL
    SELECT 4 AS id, 3 AS numD, 's' as type_Metier FROM dual )
    SELECT numD,count(*)
    FROM emp
    GROUP BY numD 
    HAVING count(*) >1 ;
    où type_Metier "s" = secretaire et "e" = employé

    le resultat done
    ce qui n'est pas le nombre de secretaire mais le nombre total d'employer

    Si tu fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    with emp AS (SELECT 1 AS id, 1 AS numD, 's' as type_Metier FROM dual union ALL
    SELECT 2 AS id, 1 AS numD, 'e' as type_Metier FROM dual union ALL
    SELECT 3 AS id, 2 AS numD, 's' as type_Metier FROM dual union ALL
    SELECT 4 AS id, 3 AS numD, 's' as type_Metier FROM dual )
    SELECT numD,count(*)
    FROM emp
    WHERE type_Metier='s' 
    GROUP BY numD 
    HAVING count(*) >1 ;
    donne :
    Alors le résultat est plus juste

    Au final c'est ton count(*) par ligne regroupé (group), ta table et tes données qui font que ça tombe juste, mais complique un peu et le résultat sera faux.

    Cordialement,
    Si un commentaire t'as aidé pense à mettre un .

Discussions similaires

  1. [JSF] comment fonctionne <h:message> ?
    Par anitshka dans le forum JSF
    Réponses: 5
    Dernier message: 29/06/2005, 17h36
  2. Comment fonctionne TXmlDocumment ????
    Par almisuifre dans le forum C++Builder
    Réponses: 8
    Dernier message: 18/02/2005, 12h54
  3. comment fonctionne une interface graphique???
    Par elekis dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 27/10/2004, 23h10
  4. Comment fonctionne le ClassExplorer ?
    Par borisd dans le forum C++Builder
    Réponses: 7
    Dernier message: 30/09/2004, 17h44
  5. Comment fonctionne le CVS ?
    Par mathieu dans le forum CVS
    Réponses: 6
    Dernier message: 23/03/2004, 11h26

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