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 :

Requête LINQ Dynamique


Sujet :

Linq

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    PMP
    Inscrit en
    Mai 2012
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : PMP
    Secteur : Transports

    Informations forums :
    Inscription : Mai 2012
    Messages : 1
    Par défaut Requête LINQ Dynamique
    Bonjour,

    Je suis nouveau à LINQ, et j'aurai besoin d'aide.

    Je voudrai pouvoir générer une requête LINQ dynamique, dont les colonnes traitées dans sa section SELECT dépendent de choix connus à la phase d'execution (liste des colonnes récupérées du GUI ou d'un fichier de conf).

    J'ai vu qu'il y'avait la possibilité via Query.Concat de faire des concaténation de requêtes, mais je ne maitrise pas vraiment LINQ pour m'y aventurer.

  2. #2
    Rédacteur
    Avatar de WOLO Laurent
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Mars 2003
    Messages
    2 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Congo-Brazzaville

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 741
    Par défaut
    Un exemple pour nous eclairer, mon chere ami.

    Découvrez la FAQ de MS SQL Server.
    La chance accorde ses faveurs aux esprits avertis !

  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
    Par défaut
    Ça n'a pas beaucoup de sens de vouloir faire ça. L'intérêt de Linq, c'est de faire des requêtes en conservant un typage fort ; si tu ne connais pas à l'avance les colonnes (et donc les propriétés des objets dans le résultat), ce n'est plus du typage fort, et Linq n'est pas fait pour ça.

    Cela dit, c'est possible d'obtenir le résultat voulu en utilisant Dynamic Linq. Tu trouveras les fichiers nécessaires dans le répertoire Samples de Visual Studio.

    ça s'utilise comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var query =
        db.Clients
            .Where(...)
            .Select("new(Id As ClientId, Name, Address, Phone As PhoneNumber)");
    Puisque le select est défini par une chaine, tu peux construire cette chaine dynamiquement...

    Par contre, les objets du résultat ne sont plus typés, ce sont juste des Object. Mais si c'est pour du binding ce n'est pas forcément gênant...

  4. #4
    Membre extrêmement actif

    Homme Profil pro
    Software Developer
    Inscrit en
    Mars 2008
    Messages
    1 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Software Developer

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 470
    Par défaut
    Tout a fait d'accord, pas vraiment d'utilité et déconseillé.

    Par ailleurs ce meme sujet a été traité il y a moins de 2 mois, merci de consulter les archives et de ne pas créer de topic en doubles.

  5. #5
    Membre très actif
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    688
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 688
    Par défaut
    Citation Envoyé par alex_vino Voir le message
    Tout a fait d'accord, pas vraiment d'utilité et déconseillé.

    Par ailleurs ce meme sujet a été traité il y a moins de 2 mois, merci de consulter les archives et de ne pas créer de topic en doubles.
    encore fallait-il le deviner...

  6. #6
    Rédacteur
    Avatar de Nathanael Marchand
    Homme Profil pro
    Expert .Net So@t
    Inscrit en
    Octobre 2008
    Messages
    3 615
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert .Net So@t
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2008
    Messages : 3 615
    Par défaut
    Citation Envoyé par guillaume07 Voir le message
    encore fallait-il le deviner...
    C'est bien pour cela qu'il y a un moteur de recherche
    http://www.developpez.net/forums/search.php

Discussions similaires

  1. [Débutant] Création de requêtes Linq dynamique
    Par patxy dans le forum VB.NET
    Réponses: 42
    Dernier message: 16/03/2012, 14h20
  2. [SQL2K][TSQL] Curseur : Requête select_statement dynamique
    Par Fred72250 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 13/09/2006, 22h31
  3. [ODBC] Afficher une requête croisée dynamique dans une page PHP
    Par resterzen dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 25/08/2006, 16h24
  4. Requête crosé dynamique avec paramètres saisi
    Par tamerlan dans le forum Access
    Réponses: 3
    Dernier message: 23/03/2006, 14h30
  5. requête croisée dynamique
    Par gregius dans le forum Access
    Réponses: 8
    Dernier message: 17/03/2006, 11h24

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