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 (colonne peut avoir la valeur NULL)


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    530
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 530
    Par défaut ORDER BY (colonne peut avoir la valeur NULL)
    Bonjour à tous,

    Dans l'optique d'afficher un tableau ou les valeurs sont classées selon un ordre croissant puis d'afficher celles pour lesquelles la valeur est NULL j'ai une colonne tinyInt dans ma BDD (NULL par défaut).

    Ma requête SELECT est la suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM maTable ORDER BY numOrdre
    Mais cette requête fait apparaitre d'abord les lignes pour lesquelles numOrdre est NULL puis par ordre croissant selon la valeur de numOrdre.

    Est-il possible de modifier cette requête de manière à faire apparaitre d'abord les lignes par ordre croissant selon la valeur de numOrdre puis les lignes pour lesquelles numOrdre est NULL ?

    Ou faut-il faire un traitement ultérieur ?

    Merci d'avance pour vos réponses.

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Certains SGBD proposent une option NULLS LAST, mais vous pouvez essayer ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM maTable ORDER BY coalesce(numOrdre, 99999999) ASC

  3. #3
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Par défaut
    Salut,

    Si tu es sous Oracle , je pense qu'il faudrait faire :
    SELECT * FROM maTable ORDER BY nvl(numOrdre, 99999999) ASC

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    530
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 530
    Par défaut
    Je suis sous MY-SQL.

    Merci Waldar,

    Cette solution fonctionne selon mes attentes.

  5. #5
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Par défaut
    Donc il faut utiliser l'exemple de Waldar.

    Remarque cela n'etait pas précisé dans ta question.

    Chacune des SGBD ont leurs spécificités, coalesce ne fonctionne pas sous Oracle

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    530
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 530
    Par défaut
    Merci pour vos réponses,

    J'ai trouvé cette syntaxe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT * FROM maTable ORDER BY IF(ISNULL(numOrdre),1,0),numOrdre;
    qui fonctionne également.

    Laquelle est la plus correcte et la plus pérène ?

  7. #7
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Citation Envoyé par beegood Voir le message
    coalesce ne fonctionne pas sous Oracle
    Il faut vous mettre à jour, car ça fonctionne très bien depuis au moins la version 9i et même 8i en googlant un peu, soit depuis une dizaine d'années.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select coalesce('Fonctionne', 'Fonctionne pas') AS test from dual

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

Discussions similaires

  1. Peut on avoir une valeur NULL dans un composite-id ?
    Par weed dans le forum Hibernate
    Réponses: 0
    Dernier message: 20/11/2008, 12h12
  2. Parmi 3 cellules, une seule peut avoir une valeur différente de 0.
    Par EricQ dans le forum Macros et VBA Excel
    Réponses: 24
    Dernier message: 07/07/2008, 15h46
  3. [Access] somme de 2 colonnes même qd une valeur nulle ?
    Par kikidrome dans le forum Langage SQL
    Réponses: 4
    Dernier message: 26/01/2008, 19h18
  4. <bean:define> ne peut recevoir une valeur null
    Par nsdcrew dans le forum Struts 1
    Réponses: 2
    Dernier message: 08/07/2007, 17h26
  5. Le champs "X" ne peut contenir une valeur Null
    Par gentoo dans le forum Access
    Réponses: 4
    Dernier message: 18/03/2007, 23h41

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