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

C# Discussion :

Trier un résultat de requête par date puis les regrouper par id.


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2011
    Messages : 72
    Par défaut Trier un résultat de requête par date puis les regrouper par id.
    Bonjour,

    J'ai une requête qui me retourne un résultat sous cette forme là
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM cal ORDER by date,id
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    id:3; date: 01.10.2012;
    id:1; date: 09.10.2012;
    id:2; date: 10.10.2012;
    id:2; date: 11.10.2012;
    id:1; date: 25.10.2012;
    J'aimerai ensuite que les avoir sous cette forme là
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    id:3; date: 01.10.2012;
    id:1; date: 09.10.2012;
    id:1; date: 25.10.2012 
    id:2; date: 10.10.2012;
    id:2; date: 11.10.2012;
    J'aimerai donc trier mon résultat par date puis regrouper mes résultat par id tout en gardant le tri par date.
    Comment faire?

    Merci d'avance

  2. #2
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Bonjour

    Le deuxième tableau n'est pas clair.
    Tu veux trier par date au sein d'un ID ? Mais l'ordre des ID que tu indiques semble aléatoire.

    Sinon, en faisant ORDER by id, date au lieu de ORDER by date,id tu auras bien entendu les lignes triées par date pour un même ID.

    Dans le cas contraire, merci de préciser.

    PS : on ne fait jamais de select * dans un programme !!!

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2011
    Messages : 72
    Par défaut
    Merci pour ta réponse.

    Ce que je veux c'est trier mon tableau pour obtenir le résultat du deuxième tableau.
    Ce que je veux faire est assez complexe. C'est d'abord trier mon tableau par date. Puis une fois qu'il est trié j'aimerai regrouper mes lignes par id. Donc si une ligne d'id 1 est en deuxième position, toutes les lignes qui ont un id 1 viennent à la suite de la première ligne qui a l'id 1.

  4. #4
    Membre éprouvé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2011
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Avril 2011
    Messages : 58
    Par défaut
    Le group By peux pas t'aider ? (j'ai un peu de mal a comprendre ce que tu veux faire) Sinon en linq tu excute ta requete order by date, et sur ton résultat tu fait un .OrderBy

  5. #5
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par Haoshin Voir le message
    Sinon en linq tu excute ta requete order by date, et sur ton résultat tu fait un .OrderBy
    Curieuse réponse ; si les données viennent d'une base, je ne vois pas du tout ce que tu peux faire avec Linq que tu ne peux pas faire (infiniment plus efficacement) avec SQL.

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2011
    Messages : 72
    Par défaut
    Merci pour vos réponses.

    Pour commencer, j'ai posté cette question dans cette rubrique car je ne savais pas si mon problème pouvait être résolu au niveau SGBD ou traitement (code).
    Ensuite, sachez que j'ai fini par résoudre mon problème en traitant mon résultat dans une boucle (usine à gaz).
    La solution de Haoshin ne résoud pas le problème, elle ne fait que le repousser :-(.
    Par contre je pense qu'un solution basée sur les fonctions de fenêtrage (que je ne connaissais pas) semble être une option intéressante.

  7. #7
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par liryks_6 Voir le message
    Merci pour ta réponse.

    Ce que je veux c'est trier mon tableau pour obtenir le résultat du deuxième tableau.
    Ce que je veux faire est assez complexe. C'est d'abord trier mon tableau par date. Puis une fois qu'il est trié j'aimerai regrouper mes lignes par id. Donc si une ligne d'id 1 est en deuxième position, toutes les lignes qui ont un id 1 viennent à la suite de la première ligne qui a l'id 1.
    Ok, je crois que vois, mais dans ce cas tu ne souhaites pas un résultat trié, contrairement à ce que tu affirmais.

    Il y a des solutions basées sur les fonctions de fenêtrage.

    Quel est le SGBD ici ?

    (par contre, je ne comprend pas pourquoi tu as posté ton problème ici, plutôt que sur le forum SQL : on voit pas trop le rapport avec le C#)

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

Discussions similaires

  1. Requête Sql qui regroupe par date
    Par stade13 dans le forum Langage SQL
    Réponses: 10
    Dernier message: 04/02/2013, 17h51
  2. Réponses: 2
    Dernier message: 31/12/2011, 18h11
  3. [JFileChooser] Trier les fichiers par date de modification
    Par stounouslous dans le forum Agents de placement/Fenêtres
    Réponses: 1
    Dernier message: 10/05/2008, 12h47
  4. Trier les données par date au format jour mois année...
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/08/2007, 11h41
  5. Trier les fichiers par type et les afficher par groupe ...
    Par KneXtasY dans le forum Autres Logiciels
    Réponses: 4
    Dernier message: 18/09/2005, 18h50

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