MYSQL PHP SELECT DISTINC INVERSé
Résolu
shetanus
-
shetanus -
shetanus -
Bonjour,
J'ai bien cherché dans les forums et trouvé des solutions... mais elle ne fonctionnent pas.
Mon probleme :
J'ai une base SQL avec les colonnes ID, PSEUDO, DATE
a chaque connexion j'insere un lien dans ma base pour des stats, ce qui donne une base du type :
1;shetanus;2007-02-23
2;teamA;2007-02-23
3;teamB;2007-02-23
4;teamA;2007-08-30
5;teamA;2007-09-01
6;teamB;2007-12-12
7;shetanus;2008-12-08
8;teamB;2008-12-20
9;shetanus;2008-12-21
AVEC LA REQUETE, SELECT id,pseudo,date FROM $table GROUP BY ip_adress, j'obtiens le résultat :
1;shetanus;2007-02-23
2;teamA;2007-02-23
3;teamB;2007-02-23
Je souhaite résupérer les valeurs les plus récentes par rapport à la date, c'est à dire :
9;shetanus;2008-12-21
8;teamB;2008-12-20
5;teamA;2007-09-01
Là, je bloque...
J'ai essayé, DISTINCT, MAX, une requete imbriquée dans une autre mais là je bloque...
Alors comme je sais que ça existe, si quelqu'un veux bien m'aider...
Merci beaucoup
J'ai bien cherché dans les forums et trouvé des solutions... mais elle ne fonctionnent pas.
Mon probleme :
J'ai une base SQL avec les colonnes ID, PSEUDO, DATE
a chaque connexion j'insere un lien dans ma base pour des stats, ce qui donne une base du type :
1;shetanus;2007-02-23
2;teamA;2007-02-23
3;teamB;2007-02-23
4;teamA;2007-08-30
5;teamA;2007-09-01
6;teamB;2007-12-12
7;shetanus;2008-12-08
8;teamB;2008-12-20
9;shetanus;2008-12-21
AVEC LA REQUETE, SELECT id,pseudo,date FROM $table GROUP BY ip_adress, j'obtiens le résultat :
1;shetanus;2007-02-23
2;teamA;2007-02-23
3;teamB;2007-02-23
Je souhaite résupérer les valeurs les plus récentes par rapport à la date, c'est à dire :
9;shetanus;2008-12-21
8;teamB;2008-12-20
5;teamA;2007-09-01
Là, je bloque...
J'ai essayé, DISTINCT, MAX, une requete imbriquée dans une autre mais là je bloque...
Alors comme je sais que ça existe, si quelqu'un veux bien m'aider...
Merci beaucoup
A voir également:
- MYSQL PHP SELECT DISTINC INVERSé
- Annuaire inversé - Guide
- Ecran inversé - Guide
- Annuaire inversé espagne - Forum Mobile
- Annuaire inversé suisse ✓ - Forum Mail
- Annuaire inverse espagne - Forum Mobile
7 réponses
MERCI A REDLIFEBIG ET LEWIS... REPONSES 11 & 13
GRACE A VOUS G REUSSIT, C'etait bien
select max(id),pseudo,max(date) from table group by pseudo;
Cela m'a permit de comprendre comment utiliser le MAX() dans SQL
Bonne continuation les gars.
GRACE A VOUS G REUSSIT, C'etait bien
select max(id),pseudo,max(date) from table group by pseudo;
Cela m'a permit de comprendre comment utiliser le MAX() dans SQL
Bonne continuation les gars.
etu a essaye avec les tableaux (array)
/ /on crée la requête SQL
$sql = 'SELECT distinct * FROM ta_table ORDER by date ASC ; //si tu veut trier par date
// on envoie la requête
$req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
// on lance la requete qui affiche les resultats suivant la condition
while($data = mysql_fetch_array($req))
{
// on affiche les informations de l'enregistrement en cours
echo '<b>'.$data['champ1'].' '.$data['champ2'].'</b> ('.$data['champ3'].')';
// bien sur tu met les champs que tu veut
}
c'est une idée comme ça..
/ /on crée la requête SQL
$sql = 'SELECT distinct * FROM ta_table ORDER by date ASC ; //si tu veut trier par date
// on envoie la requête
$req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
// on lance la requete qui affiche les resultats suivant la condition
while($data = mysql_fetch_array($req))
{
// on affiche les informations de l'enregistrement en cours
echo '<b>'.$data['champ1'].' '.$data['champ2'].'</b> ('.$data['champ3'].')';
// bien sur tu met les champs que tu veut
}
c'est une idée comme ça..
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Salut,
Je pense plutôt à :
SELECT id, pseudo, date FROM &table ORDER BY date ASC
Cette requète marchera juste si ton champ "date" est de type date/heure
J'comprend pas ce que "ip_adress" vient faire ici.
Je pense plutôt à :
SELECT id, pseudo, date FROM &table ORDER BY date ASC
Cette requète marchera juste si ton champ "date" est de type date/heure
J'comprend pas ce que "ip_adress" vient faire ici.
Merci les gars,
Pour ip_adress je me suis trompé car je travaille sur deux sites en meme temps excusez moi.
C'est bien les valeurs id,pseudo,date dont nous parlons.
C'est exactement ce que j'avais essayé au debut avec ORDER BY apres un GROUP BY pour dedoublonner...
Mais le résultat c'est qu'il me retourne le tableau inversé. exemple avec ORDER BY date ASC :
1;shetanus;2007-02-20
2;teamA;2007-02-21
3;teamB;2007-02-22
exemple avec ORDER BY date DESC :
3;teamB;2007-02-22
2;teamA;2007-02-21
1;shetanus;2007-02-20
Moi j'ai plusieurs valeurs identiques dans la colonne "pseudo" car les identifiants se connectent aléatoirement, et des dates differentes.
Je souhaite récupérer la date la plus a jour par rapport au pseudo. en gros quand il groupe les valeurs ils les groupe par ordre alphabetique, et lorsqu'il affiche les données grouppées sur ma page, c'est la date de premiere connexion qui sort et pas la derniere.
En tout cas, merci beaucoup les gars de votre aide.
Vous etes précieux dans ces moments là.
Pour ip_adress je me suis trompé car je travaille sur deux sites en meme temps excusez moi.
C'est bien les valeurs id,pseudo,date dont nous parlons.
C'est exactement ce que j'avais essayé au debut avec ORDER BY apres un GROUP BY pour dedoublonner...
Mais le résultat c'est qu'il me retourne le tableau inversé. exemple avec ORDER BY date ASC :
1;shetanus;2007-02-20
2;teamA;2007-02-21
3;teamB;2007-02-22
exemple avec ORDER BY date DESC :
3;teamB;2007-02-22
2;teamA;2007-02-21
1;shetanus;2007-02-20
Moi j'ai plusieurs valeurs identiques dans la colonne "pseudo" car les identifiants se connectent aléatoirement, et des dates differentes.
Je souhaite récupérer la date la plus a jour par rapport au pseudo. en gros quand il groupe les valeurs ils les groupe par ordre alphabetique, et lorsqu'il affiche les données grouppées sur ma page, c'est la date de premiere connexion qui sort et pas la derniere.
En tout cas, merci beaucoup les gars de votre aide.
Vous etes précieux dans ces moments là.
Bonjour.
Si je comprends bien, tu veux récupérer pour chaque PSEUDO, la dernière DATE de connexion ?
Et le MAX(DATE) ne fonctionne pas ?!
PS : Au passage (rien à voir (?) avec le problème) : évite d'appeler ton champ DATE, ça peut engendrer des conflits...
Si je comprends bien, tu veux récupérer pour chaque PSEUDO, la dernière DATE de connexion ?
Et le MAX(DATE) ne fonctionne pas ?!
PS : Au passage (rien à voir (?) avec le problème) : évite d'appeler ton champ DATE, ça peut engendrer des conflits...
Merci mac gawel, j'ai renommé la colonne date par rapport a tes conseils. renommée en visite
avec la commande MAX date, je n'obtiens qu'une seule ligne. celle de la date la plus récente.
Aurais tu une idée pour la syntaxe ?
exemple
SELECT MAX(id) FROM $table WHERE (SELECT DISTINCT pseudo FROM $table) ORDER BY visite DESC ;
ou
SELECT * FROM $table AS #temptable WHERE (SELECT MAX(visite) FROM #temptable GROUP BY pseudo) ORDER BY visite DESC ;
C trop dur...
Là je bloque.
avec la commande MAX date, je n'obtiens qu'une seule ligne. celle de la date la plus récente.
Aurais tu une idée pour la syntaxe ?
exemple
SELECT MAX(id) FROM $table WHERE (SELECT DISTINCT pseudo FROM $table) ORDER BY visite DESC ;
ou
SELECT * FROM $table AS #temptable WHERE (SELECT MAX(visite) FROM #temptable GROUP BY pseudo) ORDER BY visite DESC ;
C trop dur...
Là je bloque.