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 :

Probleme de requete avec MAX sur champ de type date


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 233
    Points : 107
    Points
    107
    Par défaut Probleme de requete avec MAX sur champ de type date
    Bonjour,

    Je n'arrive pas a faire une requete en utilisant la fonctions de groupe MAX

    J'ai fait une jointure sur 2 tables : hardware et networks

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT NAME, LASTCOME, MACADDR  FROM `hardware` JOIN `networks` ON hardware.ID = networks.HARDWARE_ID
    J'ai dans le resultat de ma 1ere requete , des vieux enregistrements que j'aimerais filtrer.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    NAME 	LASTCOME 	MACADDR
    115p1 	2013-04-09 13:11:02 	00:23:ae:91:ec:87
    115p1 	2012-05-18 14:41:02 	00:23:ae:91:0f:79
    115p10 	2013-04-05 13:20:02 	00:23:ae:93:1c:69
    115p10 	2012-05-16 14:50:02 	00:23:ae:91:0f:41
    115p11 	2013-04-10 13:21:02 	00:23:ae:93:1b:66
    115p11 	2012-05-18 14:51:02 	00:23:ae:91:df:95
    Je souhaite donc ne conserver que l'enregistrement le plus récent via la fonction MAX.

    J'ai ecris cette requete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT NAME, MAX(LASTCOME), MACADDR  FROM `hardware` JOIN `networks` ON hardware.ID = networks.HARDWARE_ID GROUP BY(NAME)
    Mais y a un kouak ... il melange les dates LASTCOME avec les adress MACADDR

    Je ne suis vraimmetn pas doué en SQL, désolé et merci d'avance pour votre aide.

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    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 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    C'est parce que toutes les colonnes du SELECT ne faisant pas l'objet d'une fonction de groupage doivent figurer dans le GROUP BY sous peine de voir des valeurs aléatoires pour les colonnes manquantes.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT NAME, MAX(LASTCOME), MACADDR
    FROM `hardware`
    JOIN `networks` ON hardware.ID = networks.HARDWARE_ID
    GROUP BY NAME, MACADDR
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  3. #3
    Membre régulier
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 233
    Points : 107
    Points
    107
    Par défaut
    Cela ne semble pas fonctionner, il me laisse les vieux enregistrement dans le tableau de resultats:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    NAME 	MAX( LASTCOME ) 	MACADDR
    115p1 	2012-05-18 14:41:02 	00:23:ae:91:0f:79
    115p1 	2013-04-09 13:11:02 	00:23:ae:91:ec:87
    115p10 	2012-05-16 14:50:02 	00:23:ae:91:0f:41
    115p10 	2013-04-05 13:20:02 	00:23:ae:93:1c:69
    115p11 	2012-05-18 14:51:02 	00:23:ae:91:df:95
    115p11 	2013-04-10 13:21:02 	00:23:ae:93:1b:66
    115p12 	2012-05-18 14:52:02 	00:23:ae:91:ed:de
    115p12 	2013-04-10 13:22:02 	00:23:ae:93:c2:98

  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    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 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Le groupage est fait sur le couple {NAME, MACADDR}. Comme pour un NAME, tu peux avoir plusieurs MACADDR, tu as plusieurs lignes pour un NAME.

    Supprime la colonne MACADDR si tu ne veux que par NAME, mais supprime le aussi du SELECT.

    Et si tu veux le MACADDR qui correspond à la dernière LASTCOME pour chaque NAME, il faut faire une jointure de cette requête avec la table pour le récupérer.

    Dans quelle table figure chaque colonne que tu utilises dans la requête ?
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  5. #5
    Membre régulier
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 233
    Points : 107
    Points
    107
    Par défaut
    NAME et LASTCOME sont dans la table hardware
    et
    MACADDR est dans la table networks

  6. #6
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    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 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Essaie comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT h.ID, h.NAME, h.LASTCOME, n.MACADDR
    FROM hardware h
    INNER JOIN networks n ON n.HARDWARE_ID = h.ID
    INNER JOIN
    (
    	SELECT NAME, MAX(LASTCOME) AS max_lastcome
    	FROM hardware
    	GROUP BY NAME
    ) tmp
    	ON tmp.NAME = h.NAME
    	AND tmp.max_lastcome = h.LASTCOME
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  7. #7
    Membre régulier
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 233
    Points : 107
    Points
    107
    Par défaut
    Oh merci bcp çà semble fonctionner sur les quelques verifications que je viens de faire.

    Je laisse ce post ouvert encore un peu le temps de confirmer.

Discussions similaires

  1. extraire Année sur champs de type Date
    Par airbeone dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 24/01/2008, 10h23
  2. Réponses: 7
    Dernier message: 23/03/2007, 14h46
  3. probleme de requete avec un champ datetime
    Par graphicsxp dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 24/02/2006, 14h32
  4. Requete avec filtre sur un champ
    Par podz dans le forum Langage SQL
    Réponses: 7
    Dernier message: 09/02/2005, 14h37
  5. Critères sur champ de type date
    Par blasco dans le forum Access
    Réponses: 2
    Dernier message: 29/10/2004, 09h48

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