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

Requêtes MySQL Discussion :

Requete sur un alias


Sujet :

Requêtes MySQL

  1. #1
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Points : 148
    Points
    148
    Par défaut Requete sur un alias
    Bonjour
    J'aimerais savoir s'il est possible de faire cette requete en ajoutant dans le WHERE de mon alias TOTAL, une condition reprenant mon alias VILLE. Si cela est possible comment faire ?

    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
    16
    SELECT distinct(nom_ville) as VILLE
    , count(BenefMinSociaux) as MINIMA
    ,(SELECT count(*) 
        FROM PREINSCRIPTION,VILLE,OBSERVATOIRE82 
        WHERE (ville_pere=num_ville or ville_mere=num_ville) 
        and int(Obs82)=Num_Obs82 
        and date_preins>=#01/01/2013# 
        and date_preins<=#12/31/2013#
     ) AS TOTAL 
    FROM PREINSCRIPTION,VILLE,OBSERVATOIRE82
    WHERE (ville_pere=num_ville or ville_mere=num_ville) 
    and int(Obs82)=Num_Obs82 
    and date_preins>=#01/01/2013# 
    and date_preins<=#12/31/2013# 
    and BenefMinSociaux=True 
    GROUP BY nom_ville
    Merci d'avance

    Djilow

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    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,

    En l'état non.


    Qu'est censé faire cette requête ?

  3. #3
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Points : 148
    Points
    148
    Par défaut
    Bonjour
    Tout d'abord merci de prendre un peu de votre temps pour m'aider.
    J'aimerais que ma requête me retourne chaque ville, avec à chaque fois le nombre de dossier qui bénéficie des minimas sociaux, et le nombre total de dossier pour cette ville en question.
    Exemple :
    1ere ligne
    VILLE: LYON
    MINIMA: 6
    TOTAL LYON: 20

    2eme ligne
    VILLE: PARIS
    MINIMA: 2
    TOTAL PARIS: 10

    J'espère que mes explications vous aideront à comprendre ma demande.
    Merci d'avance

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    ceci retourne le bon résultat ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT nom_ville AS VILLE, SUM(CASE WHEN BenefMinSociaux=True THEN 1 END) AS MINIMA, count(*) AS TOTAL
    FROM PREINSCRIPTION,VILLE,OBSERVATOIRE82
    WHERE (ville_pere=num_ville OR ville_mere=num_ville) 
    AND int(Obs82)=Num_Obs82 
    AND date_preins>=#01/01/2013# 
    AND date_preins<=#12/31/2013# 
    AND BenefMinSociaux=True 
    GROUP BY nom_ville

  5. #5
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Points : 148
    Points
    148
    Par défaut
    La requête ne passe pas.
    Erreur de syntaxe opérateur absent dans l'expression SUM(CASE WHEN BenefMinSociaux=True THEN 1 END)

    Juste une petite précision c'est que mon TOTAL doit prendre en compte tous les résultats pour la ville, que le dossier ait le droit ou non aux minimas sociaux

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

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

    dégagez de la clause WHERE le test BenefMinSociaux=True


    Concernant la partie SELECT il faut trouver la bonne syntaxe pour le test BenefMinSociaux=True.

    Selon le type de votre colonne.

  7. #7
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Points : 148
    Points
    148
    Par défaut
    Ok pour enlever la dernière condition.
    Par contre je n'arrive pas à résoudre le problème sur le test BenefMinSociaux=True

    Edit: Mon champ est de type Boolean

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    =1 ?

  9. #9
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Points : 148
    Points
    148
    Par défaut
    Bonjour
    Non pas mieux, j'ai essayé 0, 1, -1
    Rien n'y fait...

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    La syntaxe de la requete présentée est bonne, après je ne sais pas ce que vous lancez.

    Selon la doc : http://dev.mysql.com/doc/refman/5.6/...-literals.html
    ca devrait marcher avec 0/1

  11. #11
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Points : 148
    Points
    148
    Par défaut
    Merci j'ai résolu mon problème.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/07/2004, 10h21
  2. Réponses: 3
    Dernier message: 17/05/2004, 17h28
  3. requete sur un dossier
    Par vedder dans le forum Langage SQL
    Réponses: 2
    Dernier message: 23/03/2004, 14h05
  4. operation sur des alias
    Par 74160 dans le forum Requêtes
    Réponses: 4
    Dernier message: 24/11/2003, 18h19
  5. [MS-SQL]requete sur 3 tables
    Par pascalT dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 30/04/2003, 11h24

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