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 date année+mois et ID


Sujet :

Requêtes MySQL

  1. #1
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut Requete sur date année+mois et ID
    bonjour !!
    j'ai besoin de faire une page d'archive de mon blog, je cherche donc a recuperer les "id" et les "date" de ma table en considerant un truc comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select  id, date from ma_table where id having distinct date
    vous voyez le topo ?
    bon, pour ajouter de la difficulté, j'avais besoin de recuperer dans la date, que l'année et le mois, alors j'ai fait un mic-mac avec des YEAR(date) et MONTH(date) , resultat : nada!
    alors j'ai fait un champ "an_mois" qui me recupere la valeur en annéé_mois (200808 pour ce mois -ci par exemple)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select distinct an_mois  from ma_table order by an_mois desc
    ça, c'est bon mais j'ai pas l'"id"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select distinct an_mois, id  from ma_table order by an_mois desc
    et ça, ça me rajoute les "distinct id", donc tous les id , donc pas bon ...

    alors si quelqu'un a une solution, ça me sauverai
    merci d'avance

  2. #2
    Membre éclairé
    Avatar de buggen25
    Ingénieur développement logiciels
    Inscrit en
    Août 2008
    Messages
    554
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Août 2008
    Messages : 554
    Points : 709
    Points
    709
    Par défaut
    salut : essaye

    SELECT DISTINCT DISTINCT an_mois, id FROM ma_table ORDER BY an_mois DESC

    je te promet rien,

  3. #3
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    merci pour ta reponse rapide , mais ça ajoute les "distinct id", donc tous les "id"

    j'ai besoin de recuperer les id avec une seul date par id

    ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    id 1 date 2008-08
    id 2 date 2008-05
    id 3 date 2008-08
    me donne-> id 1 et 2
    donc,il me faut un truc genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select date, id from ma_tableorder by distinct date
    mais ça, ça marche pas

  4. #4
    Membre éclairé
    Avatar de buggen25
    Ingénieur développement logiciels
    Inscrit en
    Août 2008
    Messages
    554
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Août 2008
    Messages : 554
    Points : 709
    Points
    709
    Par défaut
    essay d'inverser id avec date
    SELECT distinct id,date FROM ma_table order BY date desc;

  5. #5
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    pas bon non plus

  6. #6
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Bonjour,
    Citation Envoyé par zugolin Voir le message
    j'ai besoin de faire une page d'archive de mon blog, je cherche donc a recuperer les "id" et les "date" de ma table en considerant un truc comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select  id, date from ma_table where id having distinct date
    vous voyez le topo ?
    J'avoue franchement que non .

    Si tu commençais par nous expliquer exactement ce que tu souhaites faire... Pour chaque mois (couple mois-année en fait), tu ne veux qu'un seul Id ? Si oui, c'est un Id au hasard, ou alors le premier, ou le dernier ?

    Bref, en fonction de ce que tu attends, il y a plusieurs possibilités...

    ced

  7. #7
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    tu as bien compris :
    Pour chaque mois-année, j'ai besoin d'un seul id, le premier trouvé, par exemple, mais ça, c'est pas important

  8. #8
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Et le nombre d'id pour chaque mois, ça peut aller ? Sinon, il faudra passer par une sous-requête, ce qui dégrade les performances.

    ced

  9. #9
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    ben, le truc c'est qu'il me faudra le mois d'aout 2008, mais aussi le mois d'aout 2007 (par exemple...)

  10. #10
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    salut,

    quelque chose dans ce genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select month(date),year(date),min(id) 
    from table
    group by year(date),month(date)
    et evite d'appeler une colonne date qui est un mot reservé

  11. #11
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    bon, j'ai réussi à l'avoir grâce à toi, merci bien

    par contre, n'ayant pas eu la date dans le 1ier select, j'ai fais un autre select en plus , alors, je sais pas trop où j'ai foiré ??
    voila mon code

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
     $sql_an_mois = 'SELECT  min(id) FROM blog_articles GROUP BY year(date), month(date) ';//recup des id uniques
     $quer_an_mois = mysql_query($sql_an_mois, $conn) or die(mysql_error());   
     $row_an_mois = mysql_num_rows($quer_an_mois);
     $assoc_an_mois=mysql_fetch_assoc($quer_an_mois);
     
     do{
     
     $id_mois=$assoc_an_mois['min(id)'];
     $sql_an_mois2 = "SELECT year(date), month(date), id FROM blog_articles WHERE id= '$id_mois' order by date asc";//recup des mois/ans
     $quer_an_mois2 = mysql_query($sql_an_mois2, $conn) or die(mysql_error());   
     $row_an_mois2 = mysql_num_rows($quer_an_mois2);
     $assoc_an_mois2=mysql_fetch_assoc($quer_an_mois2);
     
     $un_mois=$assoc_an_mois2['month(date)']; //date francaise
    $mois = array("Janvier", "Février", "Mars", "Avril", "Mai", "Juin",
        "Juillet", "Août", "Septembre", "Octobre", "Novembre", "Décembre");
     $lemois = $mois[$un_mois -1];//à ${hour}h${min}m${sec}s 
     
    $retourLigne = 0;
    echo  '<a href="blog_article.php?id='.$assoc_an_mois['min(id)'].'">'.$lemois.'-'.$assoc_an_mois2['year(date)'].'</a>&nbsp;&nbsp;&nbsp;';//$assocdate['date']
     $retourligne++;
    if ($retourligne>=4){ echo '<br>';
    $retourligne = 0; }
        }
    while ($assoc_an_mois=mysql_fetch_assoc($quer_an_mois));
    j'ai donc, eu mes "id" uniques par date, j'ai ensuite recupéré mes dates .

    Car, quand j'ai fait ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT month(date),year(date),min(id) 
    FROM blog_articles
    GROUP BY year(date),month(date)
    j'ai pu afficher l'id mais pas la date , c'est normal ?

  12. #12
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Quand tu dis récupérer la date, c'est le mois et l'année ou c'est la date complète correspondant à l'id que tu récupères ?

    ced

  13. #13
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    je récupère juste le mois et l'année

  14. #14
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    arrgggggggghhhhhhhh, ben dis donc, v'la que ça marche , maintenant
    c'etait louche , quand meme ... y'avait une faute quelque part , mais où ?
    enfin, c'est cool , merci a vous, voila le bout de code, si ça interresse quelqu'un ...
    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
    17
    18
    19
    20
     
     $sql_an_mois = 'SELECT  year(date), month(date),min(id) FROM blog_articles GROUP BY year(date), month(date) ';//comptage des articles YEAR
     $quer_an_mois = mysql_query($sql_an_mois, $conn) or die(mysql_error());   
     $row_an_mois = mysql_num_rows($quer_an_mois);
     $assoc_an_mois=mysql_fetch_assoc($quer_an_mois);
    //echo $assoc_an_mois['year(date)'];
     do{
     
     $un_mois=$assoc_an_mois['month(date)']; //date francaise
    $mois = array("Janvier", "Février", "Mars", "Avril", "Mai", "Juin",
        "Juillet", "Août", "Septembre", "Octobre", "Novembre", "Décembre");
     $lemois = $mois[$un_mois -1];//à ${hour}h${min}m${sec}s 
     
    $retourLigne = 0;
    echo  '<a href="blog_article.php?id='.$assoc_an_mois['min(id)'].'">'.$lemois.'-'.$assoc_an_mois['year(date)'].'</a>&nbsp;&nbsp;&nbsp;';//$assocdate['date']
     $retourligne++;
    if ($retourligne>=4){ echo '<br>';
    $retourligne = 0; }
        }
    while ($assoc_an_mois=mysql_fetch_assoc($quer_an_mois));
    ... me reste plus qu'a trouver comment afficher par date decroissante , car ça demarre par le plus ancien et j'arrive pas a demarrer au plus recent ...

  15. #15
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 034
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 034
    Points : 23 779
    Points
    23 779
    Par défaut
    Tu ajoutes à la fin de la requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ... ORDER BY year(date) DESC, month(date) DESC
    ced

  16. #16
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    ahhhh, ok !!
    je vais voir ça demain !
    merci a toi , grand samouraï !

    je croyais pas ça possible cette organisation avec "desc"

    en plus, j'avais j'amais utilisé "min(le_champ)" ...
    j'apprends 2 choses!

  17. #17
    Membre habitué Avatar de zugolin
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 267
    Points : 164
    Points
    164
    Par défaut
    euh... j'ai pas atendu demain, ça marche, merci encore !
    je résoluttise et je valide

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

Discussions similaires

  1. Requete sur l'année d'une date
    Par robbiano78 dans le forum Hibernate
    Réponses: 2
    Dernier message: 04/02/2008, 10h04
  2. [Débutant] Critères de requete sur dates - Programmation VBA
    Par Sofie109 dans le forum Requêtes et SQL.
    Réponses: 9
    Dernier message: 11/01/2007, 15h35
  3. Export Excel et formatage en date (année mois)
    Par joshua12 dans le forum Access
    Réponses: 1
    Dernier message: 20/09/2006, 00h22
  4. requete sur date
    Par fsautejeau dans le forum Requêtes et SQL.
    Réponses: 14
    Dernier message: 12/09/2006, 14h05
  5. Requete sur Date
    Par puppusse79 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 26/06/2006, 12h07

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