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

Linq Discussion :

[C#] LINQ to SQL => orderby dynamique (en string)


Sujet :

Linq

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de dacid
    Homme Profil pro
    Inscrit en
    Juin 2003
    Messages
    1 065
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 1 065
    Par défaut [C#] LINQ to SQL => orderby dynamique (en string)
    Bonjour @ tous,

    Voilà, la question est simple, mais j'ai l'impression que la réponse est compliquée.

    Je remplit une gridView depuis les entités, et j'aimerais pourvoir mettre mon orderby de manière paramétrable... De cette manière, en algorithme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
            private void chargerListe(string ordreChamp, string ordreSens) {
                using (connStrEntities bdd = new connStrEntities()) {
                    var req = from M in bdd.tblModules 
                              join S in bdd.tblSites on M.modSitId equals S.sitId
                              join T in bdd.tblTrains on M.modTrnId equals T.trnId
                              select new { M.modId, M.modLib, M.modNomFic, M.modDateMod, M.modEtat, M.modTag, M.modSitId, M.modTrnId, 
                                  S.sitLib, T.trnLib, nbImg=(from L in bdd.tblModDoc where L.mdDocId == M.modId select L).Count() }; // */
                    req.OrderBy(ordreChamp+ " " + ordreSens);
                    gvMain.DataSource = req; // */
                    gvMain.DataBind();
                }
    Mais vous devinez bien que ça ne compile même pas... Le odrerBy prends des paramètres qui me dépassent.

    Pouvez vous m'aider ?

    Merci d'avance.

  2. #2
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Février 2003
    Messages
    2 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2003
    Messages : 2 194
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    myOrdreBy= "M.modLib ascending, M.modNomFic ascending"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    private void chargerListe(string myOrdreBy) {
                using (connStrEntities bdd = new connStrEntities()) {
                    var req = from M in bdd.tblModules 
                              join S in bdd.tblSites on M.modSitId equals S.sitId
                              join T in bdd.tblTrains on M.modTrnId equals T.trnId
                              orderby myOrdreBy
                              select new { M.modId, M.modLib, M.modNomFic, M.modDateMod, M.modEtat, M.modTag, M.modSitId, M.modTrnId, 
                                  S.sitLib, T.trnLib, nbImg=(from L in bdd.tblModDoc where L.mdDocId == M.modId select L).Count() }; // */
                    gvMain.DataSource = req; // */
                    gvMain.DataBind();
                }

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875

  4. #4
    Membre éprouvé Avatar de dacid
    Homme Profil pro
    Inscrit en
    Juin 2003
    Messages
    1 065
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 1 065
    Par défaut
    Fiouf, quelle rapidité...

    Bonjour Benoit,

    C'est ce que j'ai essayé en premier mais non, ça ne fonctionne pas...

    Bonjour tomlev,

    Houlala, c'est démesuré cette librairie... Il me faut inclure la totalité du Zip à mon projet ? Il y a quand même un bon millier de fichiers...
    Je débute en Linq et je doit surement poser des questions à coté, mais ... Il n'y a pas moyen de faire un cast de ma chaine pour que ça colle au paramètres attendus par le orderby() ?

  5. #5
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Février 2003
    Messages
    2 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2003
    Messages : 2 194
    Par défaut
    Citation Envoyé par dacid Voir le message
    Fiouf, quelle rapidité...

    Bonjour Benoit,

    C'est ce que j'ai essayé en premier mais non, ça ne fonctionne pas...
    Pourtant je l'ai dans mon code mais avec une simple List<> mais je vois pas ce que ca change

    Ce passe quoi quand tu mets le orderby ?

  6. #6
    Membre éprouvé Avatar de dacid
    Homme Profil pro
    Inscrit en
    Juin 2003
    Messages
    1 065
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 1 065
    Par défaut
    TomLev,

    Bon, j'ai réussi à la mettre en place (j'ai prit le mauvais lien), mais du coup, ce n'est plus du tout du linq...
    Il n'y a pas moyen de faire l'un dans l'autre ?
    Ou alors, comment reproduire ma requête avec les jointures et le Count ?

    Benoit, je suis en Framework 4, c'est p-e pour ça que ça ne fonctionne pas... En fait, il ne se passe rien, il execute la requête mais n'effectue pas le orderBy. Mais je vais retenter malgré tout.
    Peux tu me faire voir ton exemple, STP, des fois ça ne joue à rien.
    Le list par exemple...

    David.

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

Discussions similaires

  1. Select dynamique sur PK avec LINQ to SQL
    Par celes dans le forum C#
    Réponses: 0
    Dernier message: 26/10/2012, 14h23
  2. [Linq to SQL] Clause Where dynamique
    Par Kamishu dans le forum Accès aux données
    Réponses: 2
    Dernier message: 14/08/2008, 14h17
  3. [LINQ To SQL] Clauses WHERE dynamiques
    Par SaumonAgile dans le forum Accès aux données
    Réponses: 7
    Dernier message: 23/02/2008, 01h11
  4. Réponses: 5
    Dernier message: 09/08/2005, 17h38
  5. [SQL*Plus] génération dynamique du fichier de spool
    Par lalystar dans le forum Oracle
    Réponses: 3
    Dernier message: 06/12/2004, 10h44

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