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 :

Alias et requetes imbriqués


Sujet :

Langage SQL

  1. #1
    Membre confirmé
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 504
    Points : 470
    Points
    470
    Par défaut Alias et requetes imbriqués
    bonjour,

    je lutte un peu avec un problème d'alias...

    Imaginons la requete

    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    mysql_query('select * 
    from bateau 
    where flag_bateau = 1 
      and (
        select max(date_location) as dateloc 
        from location 
        where bateau_location = bateau.id_bateau
      ) > '.time().' 
    order by dateloc');


    Sans l'alias ni le order, pas de probleme, seulement voila, j'aimerais bien faire un tri par date de location, et j'ai l'erreur "champs dateloc incconu dans order clause" ... Qu'est ce qui cloche ? Comment faire pour etendre la portée de l'alias situé dans la requete imbriqué ?

    Comment faire si je veux en plus récupérer dans mon résultat cette valeur max(date_location) ?

    En vous remerciant.

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 063
    Points
    34 063
    Billets dans le blog
    14
    Par défaut
    Si j'ai bien compris, tu veux les bateaux dont la date de location maxi est supérieure à aujourdhui ?

    Il faut donc un regroupement par bateau et une restriction sur le calcul effectué dans le regroupement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT b.id_bateau, MAX(l.date_location) AS dateloc 
    FROM bateau As b
    INNER JOIN location AS l ON b.id_bateau = l.bateau_location
    WHERE b.flag_bateau = 1 
    GROUP BY b.id_bateau
    HAVING MAX(l.date_location) > CURRENT_DATE
    ORDER BY MAX(l.date_location)
    On est dans le forum SQL et cette requête ne contient pas de PHP.

  3. #3
    Membre confirmé
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 504
    Points : 470
    Points
    470
    Par défaut
    autant pour moi, il m'avais pourtant sembler cliquer sur la sous rubrique SQL depuis le forum PHP...

    Merci pour la réponse sinon, je test ça.

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

Discussions similaires

  1. optimisé une requete SQl avec une requete imbriqués
    Par fabien14 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 16/01/2009, 10h01
  2. Requetes sql, mysql_fetch_array imbriqués = lenteur
    Par simmstein dans le forum Requêtes
    Réponses: 6
    Dernier message: 18/10/2006, 08h43
  3. alias dans une requete
    Par fscli dans le forum Access
    Réponses: 1
    Dernier message: 16/05/2006, 16h26
  4. Réponses: 7
    Dernier message: 10/02/2005, 00h13
  5. Requete select imbriqués avec plusieurs références
    Par GAlion dans le forum Langage SQL
    Réponses: 4
    Dernier message: 06/08/2004, 14h06

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