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 :

ORDER BY jour de la semaine


Sujet :

Langage SQL

  1. #1
    Membre averti
    Avatar de Cyrilange
    Profil pro
    Inscrit en
    février 2004
    Messages
    268
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : février 2004
    Messages : 268
    Points : 353
    Points
    353
    Par défaut ORDER BY jour de la semaine
    J'ai un champ "jour" dans ma table contenant le jour de la semaine sous la forme d'une chaîne de caractère (Lundi, Mardi, Mercredi etc..)

    J'aimerais trier ma table dans l'ordre des jours de la semaine à l'aide d'un ORDER BY ou autre.

    Merci de votre aide.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Ingénieur d'études décisionnel
    Inscrit en
    mai 2002
    Messages
    8 812
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur d'études décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : mai 2002
    Messages : 8 812
    Points : 29 323
    Points
    29 323
    Par défaut
    Le langage SQL étant incapable d'inventer des informations (le plugin BouleDeCristal n'est pas encre implémenté), il faut que la correspondance entre la chaine de caractères contenant le nom de jour et l'ordre dudit jour dans la semaine existe quelque part.
    L'utilisation d'un calendrier reste le moyen le plus efficace.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre averti
    Avatar de Cyrilange
    Profil pro
    Inscrit en
    février 2004
    Messages
    268
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : février 2004
    Messages : 268
    Points : 353
    Points
    353
    Par défaut
    Donc, si je comprend bien, si je convertis ma chaîne de caractère en jour de la semaine (day), le système est incapable de connaitre l'ordre des jours dans une semaine ?

  4. #4
    Modérateur

    Homme Profil pro
    Consultant Teradata
    Inscrit en
    septembre 2008
    Messages
    8 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Teradata

    Informations forums :
    Inscription : septembre 2008
    Messages : 8 150
    Points : 16 433
    Points
    16 433
    Par défaut
    Vous n'avez pas précisé votre SGBD, certains ont des fonctions qui reconnaissent les jours bien entendu.

  5. #5
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut !

    Citation Envoyé par Cyrilange Voir le message
    J'ai un champ "jour" dans ma table contenant le jour de la semaine sous la forme d'une chaîne de caractère (Lundi, Mardi, Mercredi etc..)
    J'aimerais trier ma table dans l'ordre des jours de la semaine à l'aide d'un ORDER BY ou autre
    Attribue un numéro à chaque valeur, et ordonne sur celui-ci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    ORDER BY CASE jour
                     WHEN 'Lundi' THEN 1 
                     WHEN 'Mardi' THEN 2 
                     WHEN 'Mercredi' THEN 3 
                     WHEN 'Jeudi' THEN 4 
                     WHEN 'Vendredi' THEN 5 
                     WHEN 'Samedi' THEN 6 
                     WHEN 'Dimanche' THEN 7 END

    (c'est ma photo)
    Paku, Paku !
    Pour les jeunes incultes : non, je ne suis pas un pokémon...

    Le pacblog : http://pacmann.over-blog.com/

  6. #6
    Membre averti
    Avatar de Cyrilange
    Profil pro
    Inscrit en
    février 2004
    Messages
    268
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : février 2004
    Messages : 268
    Points : 353
    Points
    353
    Par défaut
    Ma SGDB est SQL server 2005.
    Je vais retenir la solution de pacmann. En faite j'ai ajouté un champ "ordre" dans la table qui contient le numéro du jour et ça marche très bien.
    Merci à vous pour ces infos.

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

Discussions similaires

  1. Récuperer le jour de la semaine
    Par BigBeni dans le forum Assembleur
    Réponses: 5
    Dernier message: 05/04/2006, 19h50
  2. fonction pour le jour de la semaine
    Par savoir dans le forum Langage SQL
    Réponses: 6
    Dernier message: 01/06/2005, 18h24
  3. [LG]programme détermination du jour de la semaine
    Par flo.baet dans le forum Langage
    Réponses: 15
    Dernier message: 03/04/2005, 18h01
  4. Récupérez premier jour de la semaine
    Par Krapulax dans le forum Requêtes
    Réponses: 1
    Dernier message: 07/10/2003, 17h18
  5. Réponses: 3
    Dernier message: 19/04/2002, 00h11

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