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 :

Type de requête d'agrégat


Sujet :

Langage SQL

  1. #1
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut Type de requête d'agrégat
    Salam ; j'ai une table contenant des données comme suite:
    nom prénom age sexe
    aaa aaaa 03 ans Masculin
    bbb bbb 20 ans Féminin
    ccc ccc 80 ans Masculin
    zzz zzz 30 ans Féminin
    ........................................
    là je me demande comment faire la requête pour grouper les données sous la forme suivante:
    0-4 ans : Nombre de clients
    5-15 ans Nombre de clients
    16-64 ans: Nombre de clients
    >= 65 ans: Nombre de client
    est ce que je doit faire une requête par catégorie ou existe t-il autres type de requête?
    merci

  2. #2
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Il faut que tu regarde du côté du CASE pour créer des catégories.
    Puis faire une somme.

  3. #3
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,

    Vous êtes devant le même cas de figure que votre précédente demande : http://www.developpez.net/forums/d11...rois-criteres/

  4. #4
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Salam ; punkoff:
    là il s'agit de faire des agrégats de classes qui n'ont pas le même intervalle de classe , je m'explique :
    y'a classes de 00-04 ans = 05 ans d’intervalle
    y'a classes de 05-15 ans = 10 ans d’intervalle
    y'a classes de 16-64 ans = 48 ans d'intervalle
    donc c'est un peut spécifique

  5. #5
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    non c'est pareil.

    Au lieu de tester une valeur spécifique (un mois) vous allez tester un interval (0-4ans).

  6. #6
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Re ; vous pouvez me donné une démonstration de requête sur la base de mon exemple. merci

  7. #7
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Pour un interval vous devez utiliser une structure case / when comme lola vous l'indiquait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    case when ma_cond = 'X' then ma_valeur end

    Donc en reprenant tout ça quels tests avez vous effectué ?

  8. #8
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Re ; voila d'habitude mes requêtes étaient du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select  count age from table
    when age bettwen....
    mais je crois que j'étai loin des requêtes type.
    sa sous entend que je n'ai jamais utilisai les cases !!!!!!

  9. #9
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Donc as-tu une première ébauche ?

  10. #10
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 42
    Points : 39
    Points
    39
    Par défaut
    Citation Envoyé par redoran Voir le message
    Re ; vous pouvez me donné une démonstration de requête sur la base de mon exemple. merci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select 
    case
     when  age  between x and y then 'classe 1'  
    when  age  between y and z  then 'classe 2' 
    when  age  between z and t  then 'classe3'
    end as age
    from table

Discussions similaires

  1. Spécifier le type de requête (méthode OPTIONS)
    Par Tommy31 dans le forum Firefox
    Réponses: 1
    Dernier message: 06/12/2010, 10h40
  2. Suppression avec condition de type sous-requête
    Par matel dans le forum Langage SQL
    Réponses: 4
    Dernier message: 24/09/2008, 09h24
  3. Message d'erreur requête fonction agrégat
    Par luke80 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 06/04/2008, 18h58
  4. Requête d'agrégation à plusieurs niveaux
    Par rando dans le forum SQL
    Réponses: 5
    Dernier message: 12/01/2008, 13h44
  5. Requête access agrégat
    Par celiaaa dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 05/09/2007, 12h54

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