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 PostgreSQL Discussion :

Trier des partitions ainsi que les lignes dans ces partitions


Sujet :

Requêtes PostgreSQL

  1. #1
    Membre averti
    Avatar de Heavy Metal Hero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2007
    Messages : 152
    Points : 333
    Points
    333
    Billets dans le blog
    13
    Par défaut Trier des partitions ainsi que les lignes dans ces partitions
    Bonjour,

    Je suit ce tutoriel : http://www.postgresqltutorial.com/po...ndow-function/

    Je cherche un cas qui n'est pas décris dans ce tutoriel et je ne trouve pas de solution.

    A un moment du tutoriel, cette requête SELECT est utilisée pour afficher les produits regroupés par leur nom de groupe et leur prix trié par ordre croissant dans chaque groupe, voici le résultat:

    Nom : actual.jpg
Affichages : 109
Taille : 35,6 Ko

    Voici la requête aboutissant au résultat ci-dessus:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT
     product_name,
     group_name,
     price,
     ROW_NUMBER () OVER (
     PARTITION BY group_name
     ORDER BY
     price
     )
    FROM
     products
    INNER JOIN product_groups USING (group_id);
    Je vroudrais trier les lignes par prix comme dans l'exemple, ET trier les partition par ordre alphabétique descendant, ce qui donnerait:

    Nom : wanted.jpg
Affichages : 101
Taille : 32,4 Ko

    Comment puis-je modifier la requête pour obtenir ce résultat ?

    Merci de votre aide

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 801
    Points
    30 801
    Par défaut
    Pour ordonner les lignes d'une requête, il faut lui ajouter une clause ORDER BY.
    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 Heavy Metal Hero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2007
    Messages : 152
    Points : 333
    Points
    333
    Billets dans le blog
    13
    Par défaut
    Ok merci, ma solution:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT
     product_name,
     group_name,
     price,
     ROW_NUMBER () OVER (
     PARTITION BY group_name
     ORDER BY
     group_name DESC, price 
     )
    FROM
     products
    INNER JOIN product_groups USING (group_id);

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

Discussions similaires

  1. [Débutant] [VB2008] "Trier" des chars reçus et les afficher dans des labels
    Par rolf34 dans le forum VB.NET
    Réponses: 6
    Dernier message: 20/07/2011, 11h39
  2. Réponses: 3
    Dernier message: 10/09/2009, 12h35
  3. Réponses: 11
    Dernier message: 22/04/2008, 22h23
  4. Réponses: 5
    Dernier message: 19/01/2007, 22h53
  5. Réponses: 2
    Dernier message: 30/06/2006, 15h12

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