Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PHP & MySQL
PHP & MySQL Forum d'entraide sur les fonctions MySQL avec PHP. Avant de poster -> FAQ MySQL, Cours MySQL et Sources MySQL. Pour les questions concernant le moteur MySQL plutôt que les fonctions PHP, merci d'utiliser le forum MySQL.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 03/01/2011, 19h34   #1
Membre confirmé
 
Avatar de cyreel
 
Jacques KONAN
Développeur Web
Inscription : juin 2004
Messages : 342
Détails du profil
Informations personnelles :
Nom : Jacques KONAN

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : juin 2004
Messages : 342
Points : 216
Points : 216
Envoyer un message via MSN à cyreel Envoyer un message via Yahoo à cyreel
Par défaut order by sur une chaine de caractère

bonjour a tous,
j'ai une table de ma base de données mysql (que je ne peu modifier) qui a un champ de la forme (mois année) du genre.
- Octobre 2008
- janvier 2008
- aout 2007
- etc...

Je doit donc ranger cela par ordre décroissant.
le problème qui se pose à moi est qu'il affiche plutôt:
- Octobre 2008
- aout 2007
- janvier 2008

quand je fais un order by mois_anne DESC

y a t-il une solution pour ranger cela sans changer ma base de données?
cyreel est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/01/2011, 19h51   #2
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
il va falloir convertir ca en type DATE, va falloir par contre changer la locale de lc_time_names pour mettre ca en français
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/01/2011, 20h02   #3
Membre confirmé
 
Avatar de cyreel
 
Jacques KONAN
Développeur Web
Inscription : juin 2004
Messages : 342
Détails du profil
Informations personnelles :
Nom : Jacques KONAN

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : juin 2004
Messages : 342
Points : 216
Points : 216
Envoyer un message via MSN à cyreel Envoyer un message via Yahoo à cyreel
Merci @stealth35 mais comment se fait cette conversion?
Je peux avoir un exemple?
merci
cyreel est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/01/2011, 20h10   #4
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
Citation:
Envoyé par cyreel Voir le message
Merci @stealth35 mais comment se fait cette conversion?
Je peux avoir un exemple?
merci
j'ai regarder visiblement STR_TO_DATE ne prend pas la locale

http://dev.mysql.com/doc/refman/5.5/...e-support.html
Citation:
lc_time_names currently does not affect the STR_TO_DATE() or GET_FORMAT() function.
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/01/2011, 21h20   #5
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
bon c'est un peu spé mais ca marche

Code :
1
2
3
4
5
6
SELECT *, STR_TO_DATE(REPLACE(mois_anne, SUBSTRING_INDEX(mois_anne, ' ', 1 ), FIND_IN_SET(
	SUBSTRING_INDEX(mois_anne, ' ', 1 ),
	'janvier,fevrier,mars,avril,mai,juin,juillet,aout,septembre,octobre,novembre,decembre'
)), '%c %Y') AS mois_anne_date
FROM tatable
ORDER BY mois_anne_date DESC
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/01/2011, 10h15   #6
Membre confirmé
 
Avatar de cyreel
 
Jacques KONAN
Développeur Web
Inscription : juin 2004
Messages : 342
Détails du profil
Informations personnelles :
Nom : Jacques KONAN

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : juin 2004
Messages : 342
Points : 216
Points : 216
Envoyer un message via MSN à cyreel Envoyer un message via Yahoo à cyreel
Vraiment merci!!!!
ça marche nickel. je n'aurai pas trouvé ça tout seul en tout cas.
cyreel est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/01/2011, 10h24   #7
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
Citation:
Envoyé par cyreel Voir le message
Vraiment merci!!!!
ça marche nickel. je n'aurai pas trouvé ça tout seul en tout cas.
je te conseil quand même de normaliser tes dates, sachant que mysql ou php peux facilement te formater une date comme tu le souhaites
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 15h16.


 
 
 
 
Partenaires

Hébergement Web